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

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

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

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

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

サーブレット

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

Q&A

1回答

10097閲覧

データベースにinsertできない。

yuta1985

総合スコア12

JSP

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

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

サーブレット

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

0グッド

1クリップ

投稿2017/01/22 03:26

編集2017/01/22 04:47

以下のtestクラスを実行するとデータベースにデータの格納ができるのですが、

servletクラスでgetParameterを用い、jspページに入力された値を受け取り、

Daoクラスに用意したsql文実行用のメソッド(testクラスと同じ内容の、

データをinsertするsql文)を用いてデータベースに値を格納しようとすると

メソッドの戻り値が『ClassNotFoundException』になってしまいデータの格納ができません。

自分では解決できないのでご協力お願いいたします。

<<実行手順>>
動的WEBプロジェクト<プロパティー<javaのビルド・パス<ライブラリー<外部jarの追加でjdbcドライバーmysql-connecter-java-5.1.40-bin.jarを追加しています。

==========================testクラス=========================

package drinkMachine; import java.sql.*; public class test { public static void main(String[] args) { // TODO 自動生成されたメソッド・スタブ try{ Connection conn = null; Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost/example1"; String host = "root"; String password = "******"; conn = DriverManager.getConnection(url,host,password); String sql = "INSERT INTO drinkMachine(code,name,unitprice,count) VALUES(?,?,?,?)"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1,"3"); pstmt.setString(2,"オレンジジュース"); pstmt.setString(3,"2"); pstmt.setString(4,"2"); int num = pstmt.executeUpdate(); System.out.println(num); }catch(ClassNotFoundException e){ e.printStackTrace(); System.out.println("a"); }catch(SQLException e){ e.printStackTrace(); System.out.println("b"); } }

}
==========================testクラス=========================

==========================jspページ==========================

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>

<!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="/drinkMachine/addController" method="post"> 商品コード<input type="text" name="code"><br> 商品名<input type="text" name="name"><br> 金額<input type="text" name="price"><br> 数量<input type="text" name="count"><br> <input type="submit" value="送信"> </form> </body> </html> ==========================jspページ==========================

=========================servletクラス========================

package drinkMachine; import java.io.*; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** •Servlet implementation class addController */ public class addController extends HttpServlet { private static final long serialVersionUID = 1L; /** •@see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse 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); PrintWriter out = response.getWriter(); request.setCharacterEncoding("UTF-8"); String code = request.getParameter("code"); String name =request.getParameter("name"); String price = request.getParameter("price"); String count = request.getParameter("count"); T001_ITEMDao ti = new T001_ITEMDao(); int str = ti.addItem(name); out.print(str); }

}
=========================servletクラス========================

==========================Daoクラス===========================

package drinkMachine; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class T001_ITEMDao { public int addItem(String name){ try{ Connection conn = null; Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost/example1"; String host = "root"; String password = "******"; conn = DriverManager.getConnection(url,host,password); String sql = "INSERT INTO drinkMachine(code,name,unitprice,count) VALUES(?,?,?,?)"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1,"3"); pstmt.setString(2,"オレンジジュース"); pstmt.setString(3,"2"); pstmt.setString(4,"2"); int num = pstmt.executeUpdate(); return num; }catch(ClassNotFoundException e){ e.printStackTrace(); return 2; }catch(SQLException e){ e.printStackTrace(); return 3; }

}
}
========================Daoクラス===========================

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

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

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

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

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

tkmtmkt

2017/01/22 04:19

ソースコードを見やすく表示しておかないと、ほとんどの人は内容を読むことなくこのページを閉じてしまうので回答を得ることは難しいでしょう。
tkmtmkt

2017/01/22 04:23

クラスパス上にJDBCドライバがないことが原因である可能性が高いですが、具体的な対処を示すためには実行環境と手順を提示してもらう必要があります。今の質問内容に対しては「クラスパスにJDBCドライバをつかしてください」としか言いようがないです。
guest

回答1

0

String sql = "INSERT INTO drinkMachine(code,name,unitprice,count) VALUES(?,?,?,?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(1,"3");

sqlは4つ変数がありますね。
それに送る値も4つである必要があります。
String sql = "INSERT INTO drinkMachine(code,name,unitprice,count) VALUES(?,?,?,?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(1,"3",1,2);
int num = pstmt.executeUpdate();
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(2,"オレンジジュース",4,2);
int num = pstmt.executeUpdate();
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(3,"2",8,56);
int num = pstmt.executeUpdate();
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(4,"2",6,4);
int num = pstmt.executeUpdate();
と書けば通ると思います。
それから、コネクトとINSERTを別のTRY文にしないとどちらでエラーになったか解らないので分けましょう。

投稿2017/01/22 06:23

編集2017/01/22 06:24
maiko0318

総合スコア876

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問