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

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

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

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

JSP

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

Java

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

サーブレット

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

解決済

データベースから上手くデータが取れない

kokok
kokok

総合スコア0

MySQL

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

JSP

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

Java

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

サーブレット

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

1回答

0評価

0クリップ

1747閲覧

投稿2019/09/05 02:16

編集2022/01/12 10:58

jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ホーム</title> </head> <body> <form action="/webkensyu/Address" method="get"> <button type="submit" name="button1">住所一覧</button> </form> </body> </html>

java

package servlet; import java.io.IOException; import java.util.ArrayList; 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 dao.ADDR_DB; /** * Servlet implementation class Address */ @WebServlet("/Address") public class Address extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public Address() { 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()); request.setCharacterEncoding("UTF-8"); ADDR_DB addrdb = new ADDR_DB(); ArrayList<String> result = addrdb.getaddrss(); request.setAttribute("result", result); RequestDispatcher dispatcher = request.getRequestDispatcher("/address_view.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); } }

java

package dao; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; public class ADDR_DB extends DBIO{ public ADDR_DB(){ connect(); } //住所一覧取得する public ArrayList<String> getaddrss() { ArrayList<String> result = new ArrayList<String>(); try { connect(); String sql ="SELECT addrss_code FROM addresses"; PreparedStatement pstmt = conn.prepareStatement(sql); ResultSet rs = pstmt.executeQuery(); while(rs.next()) { result.add(rs.getString("address_code")); //result.add(rs.getString("address")); } }catch(SQLException e){ e.printStackTrace(); }finally { this.close(); } return result; } }

java

package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; public class DBIO { protected static final String DBNAME = "jdbc:mysql://localhost:3306/webkensyu?useUnicode =true&characterEncoding=utf8"; protected static final String DBUSER = "user"; protected static final String DBPASS = "pass"; protected Connection conn; public DBIO(){ this.connect(); } public void connect() { try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(DBNAME,DBUSER,DBPASS); } catch(SQLException e) { e.printStackTrace(); }catch(ClassNotFoundException e) { e.printStackTrace(); } } public void close() { if(conn != null) { try { conn.close(); }catch(SQLException e) { e.printStackTrace(); } } } }
//住所一覧取得する public ArrayList<String> getaddrss() {

ResultSet rs = pstmt.executeQuery();

上記のコードでエラーが出てしまいます

ArrayList<String> result = addrdb.getaddrss();

メソッドの呼び出し側でもエラーが出てしまいます。

jspの住所取得ボタンを押したら   Address サーブレットでADDR_DBを呼び出しデータベースから住所を取得し結果を address_view.jspに渡したいと考えております。

解決出来なかったのでアドバイスお願いします。

--追記部分--

at dao.ADDR_DB.getaddrss(ADDR_DB.java:26)
at servlet.Address.doGet(Address.java:39)
この辺でエラーが出ていると思い
executeQuery();や その周辺のメソッドの使い方や戻り値などについて調べてみましたが、解決できませんでした。

エラーメッセージは1000文字を超えるため 質問の依頼のところに貼り付けます。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

m.ts10806
m.ts10806

2019/09/05 02:26

エラーとはなんでしょうか。そのままコピペしてください。 またそのエラーについて調べたことや試したことがあればそれも追記してください
tetutetu
tetutetu

2019/09/05 02:36

>エラーメッセージは1000文字を超えるため 質問の依頼のところに貼り付けます。 要点を掴めるようにしましょう ・○○Exceptionが ・どこで発生しているか の最低2行で済みます。
m.ts10806
m.ts10806

2019/09/05 02:38

>エラーメッセージは1000文字を超えるため 質問は10000字まで投稿できます。
m.ts10806
m.ts10806

2019/09/05 02:39 編集

あとDBのテーブル定義もご提示ください。多分それ見せてもらうだけで解決できる内容です。
kokok
kokok

2019/09/05 02:47

CREATE TABLE webkensyu.addresses ( address_id INT NOT NULL, address_code CHAR(8) NOT NULL, address_prefecture VARCHAR(4) NOT NULL, address_city VARCHAR(10) NOT NULL, address_street VARCHAR(255), CONSTRAINT PRIMARY KEY (address_id) ); です。 カラム名のミスでした。
m.ts10806
m.ts10806

2019/09/05 02:48

設定に準ずるものはコピペが原則です。たとえどんな簡単な単語でも。 プログラム言語側からするとそういう文字列の集合体でしかないということです。
kokok
kokok

2019/09/05 03:01

ありがとうございます。 今後は、コピペするようにします。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

MySQL

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

JSP

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

Java

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

サーブレット

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