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

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

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

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

Java

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

Eclipse

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

Q&A

解決済

1回答

2122閲覧

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

tanisi6

総合スコア3

JDBC

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

Java

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

Eclipse

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

0グッド

0クリップ

投稿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

1 2import java.io.IOException; 3import java.util.List; 4 5import javax.servlet.RequestDispatcher; 6import javax.servlet.ServletException; 7import javax.servlet.annotation.WebServlet; 8import javax.servlet.http.HttpServlet; 9import javax.servlet.http.HttpServletRequest; 10import javax.servlet.http.HttpServletResponse; 11 12import ko.setu; 13import model.Beans; 14 15/** 16 * Servlet implementation class test1 17 */ 18@WebServlet("/test1") 19public class test1 extends HttpServlet { 20 private static final long serialVersionUID = 1L; 21 22 /** 23 * @see HttpServlet#HttpServlet() 24 */ 25 public test1() { 26 super(); 27 // TODO Auto-generated constructor stub 28 } 29 30 /** 31 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 32 */ 33 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 34 // TODO Auto-generated method stub 35 response.getWriter().append("Served at: ").append(request.getContextPath()); 36 37 38 setu setu2=new setu(); 39 40 41 List<Beans> beansList=setu2.get(); 42 request.setAttribute("beansList",beansList); 43 44 45 RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); 46 dispatcher.forward(request,response); 47 48 } 49 50 /** 51 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 52 */ 53 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 54 // TODO Auto-generated method stub 55 doGet(request, response); 56 57 String a=request.getParameter("text"); 58 String b=request.getParameter("texn"); 59 String c=request.getParameter("texm"); 60 61 Beans beans=new Beans(a,b,c); 62 setu setu2=new setu(); 63 setu2.post(beans); 64 65 List<Beans> beansList=setu2.get(); 66 67 request.setAttribute("beansList",beansList); 68 69 RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/lib/NewFilex.jsp"); 70 dispatcher.forward(request,response); 71 72 73 } 74 75} 76

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

package

1 2import java.io.Serializable; 3 4public class Beans implements Serializable{ 5 6 private int id; 7 public String name; 8 public String doro; 9 public String text; 10 11 public Beans() {} 12 public Beans(int id,String name,String doro,String text) { 13 14 this.id=id; 15 this.name=name; 16 this.doro=doro; 17 this.text=text; 18 19 20 21 } 22 23 24public Beans(String name,String doro,String text) { 25 26 this.name=name; 27 this.doro=doro; 28 this.text=text; 29 30 31 32 } 33 34 35public int getId() {return id;} 36public String getName() {return name;} 37public String getDoro() {return doro;} 38public String getText() {return text;} 39 40 41 42 43 44 45} 46

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

```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>

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

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

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

回答1

0

自己解決

Class.forName()を記述したら解決しました。

投稿2022/01/01 05:21

tanisi6

総合スコア3

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問