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

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

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

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

解決済

jdbcドライバ接続について H2データベース

tanisi6
tanisi6

総合スコア3

JDBC

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

1回答

0評価

0クリップ

616閲覧

投稿2021/12/30 07:54

初心者です。eclipseでH2データベースを使い、簡単な掲示板のようなものを作りたいのですが、実行すると例外が投げられます。No suitable driver found for~とコンソールに出ているのですが、データベースとうまく接続できていないのでしょうか?
データベースからSELECT文で取り出す処理だけを書いたクラスを作り、javaアプリケーションで実行した場合は、コンソールに正常に表示されるのですが、サーバーで実行するとうまくいきません。拡張for文のところでorg.apache.jasper.JasperException: An exception occurred processingと出ます。
コードに問題があるのか、JDBCドライバがうまく設置できていないのか、コードに問題がある場合どこがいけないのか教えていただきたいです。よろしくお願いします。

サーブレット

package

import java.io.IOException; import java.util.List; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import ko.setu; import model.Beans; /** * Servlet implementation class test1 */ @WebServlet("/test1") public class test1 extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public test1() { super(); // TODO Auto-generated constructor stub } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub response.getWriter().append("Served at: ").append(request.getContextPath()); setu setu2=new setu(); List<Beans> beansList=setu2.get(); request.setAttribute("beansList",beansList); RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); dispatcher.forward(request,response); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); String a=request.getParameter("text"); String b=request.getParameter("texn"); String c=request.getParameter("texm"); Beans beans=new Beans(a,b,c); setu setu2=new setu(); setu2.post(beans); List<Beans> beansList=setu2.get(); request.setAttribute("beansList",beansList); RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); dispatcher.forward(request,response); } }

スコープに保存するクラス

package

import java.io.Serializable; public class Beans implements Serializable{ private int id; public String name; public String doro; public String text; public Beans() {} public Beans(int id,String name,String doro,String text) { this.id=id; this.name=name; this.doro=doro; this.text=text; } public Beans(String name,String doro,String text) { this.name=name; this.doro=doro; this.text=text; } public int getId() {return id;} public String getName() {return name;} public String getDoro() {return doro;} public String getText() {return text;} }

データベースとの接続をするクラス```ここに言語を入力
コード

```package ko; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import model.Beans; public class setu { public void post(Beans beans) { try(Connection conn=DriverManager.getConnection("jdbc:h2:tcp://localhost/~/mydb","sa","")){ String sql="INSERT INTO TD(NAME,DORO,TEXT) VALUES(?,?,?)"; PreparedStatement stmt=conn.prepareStatement(sql); stmt.setString(1,beans.getName()); stmt.setString(2,beans.getDoro()); stmt.setString(3,beans.getText()); int i=stmt.executeUpdate(); }catch (SQLException e) { e.printStackTrace(); System.out.println("kamo"); } } public List<Beans> get() { List<Beans> beansList=new ArrayList<>(); try(Connection conn=DriverManager.getConnection("jdbc:h2:tcp://localhost/~/mydb","sa","")){ String spl="SELECT ID,NAME,DORO,TEXT FROM TD"; PreparedStatement stnt=conn.prepareStatement(spl); ResultSet rs=stnt.executeQuery(); while (rs.next()) { int id=rs.getInt("ID"); String name=rs.getString("NAME"); String doro=rs.getString("DORO"); String text=rs.getString("TEXT"); Beans beans=new Beans(id,name,doro,text); beansList.add(beans); } }catch (SQLException e) { e.printStackTrace(); return null; } return beansList; } }

表示するjspファイル

pageEncoding="UTF-8"%> <%@ page import="model.Beans,ko.setu,java.util.List" %> <% List<Beans> beansList=(List<Beans>)request.getAttribute("beansList");%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="/ka/test1" method="Post"> <input type="text" name="text"> <input type="text" name="texn"> <input type="text" name="texm"> <input type="submit" value="e"> </form> <%for(Beans beans:beansList){%> <p><%= beans.getName()%>:<%= beans.getDoro()%>:<%= beans.getText()%>:<%= beans.getId() %></p> <% }%> </body> </html>

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

m.ts10806

2021/12/30 10:07

そもそもH2はどのようにセットアップされたのでしょうか 「No suitable driver found」の原因はそんなに多岐には渡りません。 コード見る限り、対象のDBのドライバーを利用するための記述が見当たりませんが。
tanisi6

2021/12/30 10:32

コンテナのApache Tomcat内のlibファイルにjdbcドライバーを配置して、クラスパスにjdbcドライバーを追加しました。 ドライバーに接続する際もコードを書かなければいけないのでしょうか?
m.ts10806

2021/12/30 11:06 編集

No suitable driver foundで調べたらClass.forName(Driverのクラスパス)という記述はteratailの過去質問含めて大量に出てくると思います。
tanisi6

2021/12/30 12:01

ありがとうございます。 過去の質問を見ていたらWEBアプリケーションで実行するにはWEB-INEのlibに配置しなければならないという回答を見つけたのですが、何を配置するのでしょうか?DB接続に関するコードを書いたクラスを配置したのですが、そういうことで合っていますか?
m.ts10806

2021/12/31 07:04

どのように探して・また、WEB-INFと本質問との関連性が不明ですが、私が提示した「Class.forName(Driverのクラスパス)という記述」のほうを先に試してください。
tanisi6

2022/01/01 05:20

おっしゃられた通りに試したところ解決しました。ありがとうございます。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

JDBC

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。