質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

サーブレット

サーブレット(Servlets)とはウェブやアプリケーションサーバー上に動くプログラムのことであり、ウェブブラウザや他のHTTPクライエントとデータベースやHTTPサーバー上のアプリケーションの中間層としての働きをします。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

解決済

サーブレットで、H2のDB接続をコネクションプールを利用して行い、テーブルの一覧を表示したいです。

seto718
seto718

総合スコア0

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

サーブレット

サーブレット(Servlets)とはウェブやアプリケーションサーバー上に動くプログラムのことであり、ウェブブラウザや他のHTTPクライエントとデータベースやHTTPサーバー上のアプリケーションの中間層としての働きをします。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

1回答

0評価

0クリップ

23閲覧

投稿2019/12/14 17:15

編集2022/01/12 10:58

前提・実現したいこと

サーブレットを勉強中の初心者です。参考書の通りに行っているのですがエラーが解消できず困っております。
H2のDB接続をコネクションプールを利用して行い、テーブルの一覧を表示したいです。

発生している問題・エラーメッセージ

コンパイルをする際に、while文で何故かセミコロンを入れるようエラーメッセージが出ます

chapter14\All.java:30: エラー: ';'がありません While(rs.next()){ ^ エラー1個

該当のソースコード

ALL.javaファイルの中身です

java

package chapter14; import tool.Page; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.*; import javax.servlet.annotation.WebServlet; import javax.naming.InitialContext; import javax.sql.DataSource; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; @WebServlet(urlPatterns={"/chapter14/all"}) public class All extends HttpServlet{ public void doGet ( HttpServletRequest request, HttpServletResponse response )throws ServletException,IOException { PrintWriter out=response.getWriter(); Page.header(out); try { InitialContext ic=new InitialContext(); DataSource ds=(DataSource)ic.lookup("java:/comp/env/jdbc/book"); Connection con=ds.getConnection(); PreparedStatement st=con.prepareStatement("SELECT * FROM product"); ResultSet rs=st.executeQuery(); While(rs.next()){ out.println(rs.getInt("id")); out.println(":"); out.println(rs.getString("name")); out.println(":"); out.println(rs.getInt("price")); out.println("<br>"); } rs.close(); con.close(); } catch(Exception e){ e.printStackTrace(out); } Page.footer(out); } }

コネクションプールの設定

xml

<Context reloadable="true"> <Resource name="jdbc/book" auth="Container" type="javax.sql.DataSource" driverClassName="org.h2.Driver" url="jdbc:h2:tcp://localhost/~/book" username="sa" password="" /> </Context>

Database

SELECT * FROM PRODUCT ; ID NAME PRICE 1 まぐろ 100 2 サーモン 100 3 えび 100 4 いか 100 5 えんがわ 100 6 あなご 100 7 たまご 100 8 ほたて 100 9 赤貝 100 10 つぶ貝 100 11 サラダ軍艦 150 (11 rows, 0 ms)

試したこと

whileを使わない状態でDB接続文の後にout.println("test");で試したところ、testが正常に表示されました。
一括取得した変数rsがどのような状態か見たいためour.println(rs.getInt("id"));とすると、ブラウザ画面に以下のエラーメッセージが
表示されます

test org.h2.jdbc.JdbcSQLException: 有効なデータがありません No data is available [2000-194] at org.h2.message.DbException.getJdbcSQLException(DbException.java:345)・・・

上記の結果から
①コネクションプールを使わないやり方を調べてDB接続を試みましたが、while文のコンパイルで同じ結果になりました
Class.forName("JDBCのクラス名");
Connection conn = DriverManager.getConnection("接続文字列","ユーザー名","パスワード");
等・・
②while文の閉じカッコ(})に';'をつけましたが、エラー文は変わりませんでした。
③H2の接続ドライバを新しくするために、テキスト本の用意した開発環境のzipフォルダをダウンロードし直し、
work/h2/binへh2-1.4.194.jarをコピペしましたが、状況は特に変わりませんでした。
④開いているh2の8082ポートを全て閉じ、再起動してコンパイルしましたが、whileで同じエラーでした。

while文を一体どうしたら良いのか・・・数時間悩んでいるのですがお手上げです・・・
同じ本を使っている方(基礎からのサーブレット/jsp)や詳しい方がいらっしゃいましたらご教授願います

補足情報(FW/ツールのバージョンなど)

jdkのバージョン: jdk1.8.0_121
エディタ:ATOM

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

サーブレット

サーブレット(Servlets)とはウェブやアプリケーションサーバー上に動くプログラムのことであり、ウェブブラウザや他のHTTPクライエントとデータベースやHTTPサーバー上のアプリケーションの中間層としての働きをします。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます