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

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

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

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

Tomcat

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

Q&A

解決済

1回答

1711閲覧

ps.executeUpdate();を利用して会員削除

arin

総合スコア5

Java

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

Tomcat

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

0グッド

0クリップ

投稿2021/04/14 13:40

ps.executeUpdate();を利用してDBを削除

javaで会員サイトの削除機能を作ろうとしています。
DBに接続して会員idから探して削除したいです。
検索してもps.executeUpdate();の使い方などわからなかったので書き込みました。

DBに接続して会員idから探すクラス

package service; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import data.Customer; public class DeleteService { public List<Customer> deleteCustomer (String id) { String dbName = "system_user"; String dbPropaties = "?cvharacterEncoding=UTF-8&serverTimezone=JST"; String dbUrl ="jdbc:mySQL://localhost:3306/" + dbName +dbPropaties; String dbUser = "root"; String dbPassword = "admin"; String sql = "delete from customer where id=?;"; List<Customer>customerList = new ArrayList<Customer>(); try { Class.forName("com.mysql.jdbc.Driver"); Connection coon = DriverManager.getConnection(dbUrl, dbUser, dbPassword); PreparedStatement ps = coon.prepareStatement(sql); ps.setString(1, id); ResultSet rs = ps.executeQuery(); ps.executeUpdate(); while (rs.next()) { Customer customer = new Customer(); customer.setEmail(rs.getString("email")); customer.setPassword(rs.getString("password")); customer.setName(rs.getString("name")); customer.setGender(rs.getString("gender")); customer.setBlood(rs.getString("blood")); customer.setOld(rs.getInt("old")); customerList.add(customer); } }catch (SQLException | ClassNotFoundException e) { e.printStackTrace(); } return customerList ; } }

上記を呼び出すクラス

package controller; import java.io.IOException; import java.util.List; import javax.servlet.ServletContext; 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 data.Customer; import service.UpdateService; @WebServlet("/delete") public class DeleteController extends HttpServlet { protected void doPost (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ } }

補足情報(FW/ツールのバージョンなど)

Eclipse
tomcat

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

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

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

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

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

guest

回答1

0

ベストアンサー

削除機能、であれば、以下で十分でしょう。
まず、削除機能が何かのリストを返そうとすること自体がまちがいなのではないでしょうか。
また、Tomcat云々以前の問題なので、mainメソッドを定義するなり、JUnitでテストを書くなりして、deleteCustmerメソッドを呼び出すテストをしてみてはいかがでしょうか。

java

1 2 public void deleteCustomer (String id) { 3 String dbName = "system_user"; 4 String dbPropaties = "?cvharacterEncoding=UTF-8&serverTimezone=JST"; 5 String dbUrl ="jdbc:mySQL://localhost:3306/" + dbName +dbPropaties; 6 String dbUser = "root"; 7 String dbPassword = "admin"; 8 try { 9 Class.forName("com.mysql.jdbc.Driver"); 10 Connection coon = DriverManager.getConnection(dbUrl, dbUser, dbPassword); 11 String sql = "delete from customer where id=?;"; 12 PreparedStatement ps = coon.prepareStatement(sql); 13 ps.setString(1, id); 14 ps.executeUpdate(); 15 ps.close(); 16 coon.close(); 17 } catch (SQLException | ClassNotFoundException e) { 18 e.printStackTrace(); 19 } 20 }

投稿2021/04/15 00:02

shiketa

総合スコア4038

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

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

arin

2021/04/15 06:13 編集

回答ありがとうございます。 JUnit初めて聞きましたが調べて取り組んでみます! void型にしたら呼び出して処理できなくないですか? package controller; import java.io.IOException; import javax.servlet.ServletContext; 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 service.DeleteService; @WebServlet("/delete") public class DeleteController extends HttpServlet { protected void doPost (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{ String id = request.getParameter("id"); DeleteService deleteservice = new DeleteService(); deleteservice.deleteCustomer(id); ServletContext sc = getServletContext(); sc.getRequestDispatcher("/" + "delete.jsp").forward(request, response); } }
shiketa

2021/04/15 13:21 編集

> void型にしたら呼び出して処理できなくないですか? これは「戻り地がvoidのメソッドは呼び出すことができないのではないか」という意味でしょうか? https://docs.oracle.com/javase/jp/11/docs/api/index.html は参照したことありますよね。戻り値がvoidのメソッドなんて山ほどあります。メソッドなのでもちろん呼び出して処理できます。そしてそれらのメソッドは何も返さない。それだけです。わたしは、削除処理に戻り値は不要とかんがえましたので回答「案」ではvoidとしました。案です。 たとえば、ps.executeUpdate()メソッドは、処理した件数を返してくれますので、deleteCustomer()メソッドの戻り値をintにして、削除した件数を返すようにしてもいいかもしれません。必要に応じて、お好きにどうぞ。
arin

2021/04/15 13:37

なるほど、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.38%

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

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

質問する

関連した質問