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

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

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

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

Eclipse

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Q&A

解決済

1回答

3813閲覧

JavaServletでのデータベースの更新について

liuchao4664

総合スコア13

Java

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

Eclipse

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

0グッド

0クリップ

投稿2017/01/12 23:23

サーブレット上でデータベース更新のコードを書きましたが、うまく実行できませんでした。
内容は
・テーブルtenの要素の挿入
・ten_shipment要素は「?」と指定、メソッドPreparedStatementで値を渡す

以下、プログラムになります。
DBst.java

package

1 2import java.io.IOException; 3import java.sql.Connection; 4import java.sql.PreparedStatement; 5 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 12 13/** 14 * Servlet implementation class DBst 15 */ 16@WebServlet("/DBst") 17public class DBst extends HttpServlet { 18 private static final long serialVersionUID = 1L; 19 20 /** 21 * @see HttpServlet#HttpServlet() 22 */ 23 public DBst() { 24 super(); 25 // TODO Auto-generated constructor stub 26 } 27 28 /** 29 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 30 */ 31 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 32 // TODO Auto-generated method stub 33 34 Connection con = null; 35 36 37 try{ 38 con = DBManager.getConnection(); 39 40 String sql = "INSERT INTO ten (ten_id,ten_name,ten_date,ten_shipment) " 41 + "VALUES (555,'テスト2','1月11日',?"; 42 PreparedStatement pstm = con.prepareStatement(sql) 43 44 pstm.setInt(1,4); 45 46 }catch(Exception e){ 47 e.printStackTrace(); 48 49 50 } 51 52 /** 53 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 54 */ 55 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 56 // TODO Auto-generated method stub 57 } 58 59} 60 61コード

DBManager.java

package

1import java.sql.Connection; 2import java.sql.DriverManager; 3public class DBManager { 4 public static Connection getConnection(){ 5 String driver ="com.mysql.jdbc.Driver"; 6 String url ="jdbc:mysql://localhost/satotest"; 7 String option ="?useUnicode=true&characcerEncoding=UTF-8"; 8 String user ="root"; 9 String pass = ""; 10 11 Connection con = null; 12 try{ 13 14 Class.forName(driver); 15 con =DriverManager.getConnection( 16 url + option,user,pass); 17 }catch(Exception e){ 18 e.printStackTrace(); 19 } 20 return con; 21 22 } 23} 24 25コード

servlet、jspを初めてまだ日が浅いので、アドバイスをいただきたいです。
よろしくお願い致します。

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

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

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

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

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

Batoh33789

2017/01/13 01:14

どううまくいかなかったのか、どんなエラーメッセージが出たかを記載頂ければ、回答が付きやすいと思います。またEclipseで開発されているようですので、デバッグモードで動かせば、そもそもServletまで行けているのか、Servletまで来ている場合、どこで止まったのかの切り分けが出来るかと思います。是非お試しください。
guest

回答1

0

ベストアンサー

「pstm.executeUpdate()」してないからデータ更新されないのでは?

投稿2017/01/13 01:43

tkturbo

総合スコア5572

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

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

liuchao4664

2017/01/13 02:17

tkturboさん、Batoh33789さん、ご指摘ありがとうございました。 ①pstm.executeUpdate()を追加し ②String sql = "INSERT INTO ten (ten_id,ten_name,ten_date,ten_shipment) " + "VALUES (555,'テスト2','1月11日',?"; の最後に[)]を補ったらうまく実行できました。 本当にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問