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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

0回答

724閲覧

JSP MySQL接続確認

kitten

総合スコア25

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2019/01/12 01:55

編集2019/01/12 02:15

実現したいこと

タイトルの通りJSPからMySQLに接続できるか
実際にブラウザに作成済みDBを表示して確認をしたい。

解決したいこと

下記のエラーが出ないようにしたい。
またうまくMySQLに接続できるようにしたい。

実際に試したこと

まずリンク内容を参考にJDBCドライバを入れました。

またリンク内容
のソースをほぼそのまま利用させて頂いております。

search.jspのimport部分は上記URLのものから少し変更してあります。
また、同じくsearch.jspのDatasource dsの部分も変更済(以下参照)

##気になっていること
上記で挙げた2つのサイトではsearch.jspのDatasource dsの部分が
"jdbc:mysql:// から始まっていますが
サイトによっては"java:comp/となっているものもあります。

この2つの違いがよく分かりません。

search.jsp

JSP

1<%@ page contentType="text/html; charset=Shift-JIS"%> 2<%@ page import="java.text.SimpleDateFormat, 3 java.sql.*, 4 javax.sql.*, 5 javax.naming.InitialContext, 6 javax.naming.Context" %> 7 8<html> 9 <head> 10 <title>showTable.jsp</title> 11 </head> 12 <body> 13 14 <% 15 InitialContext initCon = new InitialContext(); //(1) 16 DataSource ds 17 = (DataSource)initCon.lookup("jdbc:mysql://localhost/katadana_db?"+"user=aaaaa&password=bbbbb"); //(2) 18 Connection con = ds.getConnection(); //(3)JNDIリソースへのコネクト 19 Statement stmt = con.createStatement(); //(4) 20 ResultSet result 21 = stmt.executeQuery("select * from search;"); //(5)SQL文の実行 22 %> 23 24 <table border="1"> 25 <tr> 26 <th>id</th> 27 <th>number</th> 28 </tr> 29 30 //(6)データの表示 31 <% 32 while (result.next()) { 33 %> 34 35 <tr> 36 <td> <%= result.getString(1) %></td> 37 <td> <%= result.getString(2) %></td> 38 </tr> 39 40 <% 41 } 42 //(7)コネクトのクローズ 43 con.close(); 44 initCon.close(); 45 %> 46 </table> 47 </body> 48</html>

Error

ExceptionReport

1 2 3HTTPステータス 500 – Internal Server Error 4Type Exception Report 5 6メッセージ [/jsp/search.jsp] の処理中に行番号 [16] で例外が発生しました。 7 8説明 The server encountered an unexpected condition that prevented it from fulfilling the request. 9 10例外 11 12org.apache.jasper.JasperException: [/jsp/search.jsp] の処理中に行番号 [16] で例外が発生しました。 13 1413: 1514: <% 1615: InitialContext initCon = new InitialContext(); //(1) 1716: DataSource ds = (DataSource)initCon.lookup("jdbc:mysql://localhost/katadana_db?"+"user=aaaaa&password=bbbbb"); //(2) 1817: Connection con = ds.getConnection(); //(3)JNDIリソースへのコネクト 1918: Statement stmt = con.createStatement(); //(4) 2019: ResultSet result 21 22 23Stacktrace: 24 org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:625) 25 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:499) 26 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386) 27 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330) 28 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 29 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 30原因 31 32javax.servlet.ServletException: javax.naming.NameNotFoundException: 名前 [jdbc:mysql://localhost/katadana_db?user=takahashi&password=takahashiryo] はこのコンテキストにバインドされていません 33 org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:667) 34 org.apache.jsp.jsp.search_jsp._jspService(search_jsp.java:190) 35 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) 36 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 37 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476) 38 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386) 39 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330) 40 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 41 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 42原因 43 44javax.naming.NameNotFoundException: 名前 [jdbc:mysql://localhost/katadana_db?user=takahashi&password=takahashiryo] はこのコンテキストにバインドされていません 45 org.apache.naming.NamingContext.lookup(NamingContext.java:817) 46 org.apache.naming.NamingContext.lookup(NamingContext.java:173) 47 org.apache.naming.SelectorContext.lookup(SelectorContext.java:163) 48 java.naming/javax.naming.InitialContext.lookup(InitialContext.java:409) 49 org.apache.jsp.jsp.search_jsp._jspService(search_jsp.java:138) 50 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) 51 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 52 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476) 53 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386) 54 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330) 55 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 56 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 57注意 原因のすべてのスタックトレースは、サーバのログに記録されています 58 59Apache Tomcat/9.0.14 60

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問