###前提・実現したいこと
現在javaを勉強しているものです。
簡易チャットを作成していてDBに接続し
投稿者ID、投稿者名、投稿文、投稿日時をSystemoutで出力するプログラムをつくりたいのですがエラーが出てしまいます。
おそらくDBのSQLが間違っているのかもしれません。
このソースのどこを改善すればよいでしょうか?
ご教授お願い致します。
###発生している問題・HTTPステータス404
type ステータスレポート メッセージ 説明 The requested resource is not available.
###サーブレット
java
1 2/** 3 * Servlet implementation class ChatServlet 4 */ 5@WebServlet("/ChatServlet") 6public class ChatServlet extends HttpServlet { 7 8 9 private static final long serialVersionUID = 1L; 10 11 12 /** 13 * @see HttpServlet#HttpServlet() 14 */ 15 public ChatServlet() { 16 17 super(); 18 19 } 20 21 22 /** 23 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 24 */ 25 @Override 26 protected void doGet( HttpServletRequest request, HttpServletResponse response ) throws ServletException, IOException { 27 28 this.doPost( request, response ); 29 } 30 31 32 /** 33 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 34 */ 35 @Override 36 protected void doPost( HttpServletRequest request, HttpServletResponse response ) throws ServletException, IOException { 37 38 response.setContentType( "text.html ;charset =UTF-8" ); 39 request.setCharacterEncoding( "UTF-8" ); 40 41 ChatDB cdb = new ChatDB(); 42 cdb.getCHATdb( 1 ); 43 44 } 45 46} 47
###DB
java
1 2 3public class ChatDB { 4 5 6 private final static String DRIVER_NAME = "org.h2.Driver"; 7 8 private final static String JDBC_URL = "jdbc:h2:~/test"; 9 10 private final static String DB_USER = "Me"; 11 12 private final static String DB_PASS = ""; 13 14 15 public static void getCHATdb( int i ) { 16 17 int argument = i; 18 Connection conn = null; 19 20 try { 21 //データベースへ接続 22 Class.forName( DRIVER_NAME ); 23 conn = DriverManager.getConnection( JDBC_URL, DB_USER, DB_PASS ); 24 25 //SELECT文の準備 26 String sql = "SELECT * FROM CHATDB WHERE ID =" + argument; 27 28 PreparedStatement pStmt = conn.prepareStatement( sql ); 29 30 //INSERT文を実行 31 ResultSet result = pStmt.executeQuery(); 32 33 34 int id = 0; 35 String title = ""; 36 String body = ""; 37 String date = ""; 38 while ( result.next() ) { 39 id = Integer.parseInt( result.getString( "ID" ) ); 40 title = result.getString( "TITLE" ); 41 body = result.getString( "BODY" ); 42 date = result.getString( "DATE" ); 43 44 System.out.println( "ID:" + id ); 45 System.out.println( "TITLE:" + title ); 46 System.out.println( "BODY:" + body ); 47 System.out.println( "DATE:" + date ); 48 } 49 50 } catch ( SQLException e ) { 51 e.printStackTrace(); 52 } catch ( ClassNotFoundException e ) { 53 e.printStackTrace(); 54 } finally { 55 try { 56 if ( conn != null ) { 57 conn.close(); //データベースの切断 58 } 59 } catch ( SQLException e ) { 60 e.printStackTrace(); 61 } 62 } 63 } 64 65} 66
###SQL
ID VARCHAR TITLE VARCHAR BODY VARCHAR DATE TIMESTAMP
でテーブルを作りました。
###補足情報(言語/FW/ツール等のバージョンなど)
eclipse 4.3
JDK 1.7
Tomcat 7
H2
###追記
DBにID、TITLE,BODYだけ登録して実行するとDATEがnullになり、
systemoutで出力すると
ID:1
TITLE:おはよう
BODY:おはようございます
DATE:null
とでます。
INSERTでデータを追加するときにどのように記述すればよいのでしょうか。。
回答2件
あなたの回答
tips
プレビュー