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

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

新規登録して質問してみよう
ただいま回答率
85.48%
DAO(Data Access Object)

DAO(Data Access Object)とは、データベースなどに保存するための操作を実装したオブジェクトのことです。データの永続化機構に抽象化されたインタフェースを提供し、データベースの詳細を隠蔽。ビジネスロジックとデータ操作も分離できます。

JSP

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

Java

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

0回答

2114閲覧

チェックボックスでのデータベース削除について

apa____m

総合スコア3

DAO(Data Access Object)

DAO(Data Access Object)とは、データベースなどに保存するための操作を実装したオブジェクトのことです。データの永続化機構に抽象化されたインタフェースを提供し、データベースの詳細を隠蔽。ビジネスロジックとデータ操作も分離できます。

JSP

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

Java

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/06/17 04:12

jsp上で選択したチェックボックスの値(id)をjsp→サーブレット→DAOの順で渡し、
idで指定したテーブルをデータベースから削除したいです。

■■
現状は、削除したい情報を選択し削除ボタンを押し、確認ダイアログが出て
OKボタンを押すと、500エラー(null)が出てしまいます。

for servlet [VisitorDelete] in context with path [/App] threw exception [null] with root cause

jsp

1<script> 2 function delete_btn() { 3 4 const arr = []; 5 const del = document.getElementsByName("del"); 6 7 for (let i = 0; i < del.length; i++) { 8 if (del[i].checked) { 9 arr.push(del[i].value); 10 } 11 } 12 13 if(arr.length == 0){ 14 alert("削除する予約情報を選択してください。"); 15 window.reload(); 16 } 17 18 document.getElementById("span2").textContent = arr; 19 20 var ret = confirm("選択された" + arr.length + "件の予約情報を削除します。\nよろしいでしょうか?"); 21 22 if (ret == true) { 23 confirm("選択された" + arr.length + "件の予約情報を削除しました。"); 24 document.deleteForm.submit(arr); 25 26 } else { 27 document.getElementById("checkbox").checked = false; 28 } 29 } 30 31 </script> 32 33 34 35 <form id="delete" method="post" name="deleteForm" action="<%= request.getContextPath() %>/VisitorReservation/delete"> 36 <label class="ECM_CheckboxInput"> 37 <input class="ECM_CheckboxInput-Input" id="checkbox" type="checkbox" name="del" value="<%= yoyaku.getYoyakuId() %>"> 38 <span class="ECM_CheckboxInput-DummyInput"></span><span class="ECM_CheckboxInput-LabelText"></span> 39 </label> 40 </form>

java

1 /** 2 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 3 */ 4 protected void doPost(HttpServletRequest request, HttpServletResponse response) 5 throws ServletException, IOException { 6 // TODO Auto-generated method stub 7 8 RequestDispatcher dispatcher = null; 9 String[] idGet = request.getParameterValues("del"); 10 11 for(int i=0; i<idGet.length; i++) { 12 13 try { 14 YoyakuDao.getInstance().DeleteYoyakuData(idGet[i]); 15 }catch (SQLException e) { 16 e.printStackTrace(); 17 throw new ServletException(); 18 } 19 } 20 21 dispatcher = request 22 .getRequestDispatcher("/jsp/visitor/delete.jsp"); 23 dispatcher.forward(request, response); 24 25 } 26 27}

java

1 public void DeleteYoyakuData(String idGet) 2 throws SQLException { 3 StringBuffer SQLBuff = new StringBuffer(); 4 5 SQLBuff.append("DELETE T_YOYAKU "); 6 SQLBuff.append(" FROM T_YOYAKU "); 7 SQLBuff.append(" WHERE "); 8 SQLBuff.append(" YOYAKU_ID = " + idGet + ""); 9 10 SqliteManager.Delete(SQLBuff.toString()); 11 12 }

IDが上手く渡せていないと思うんですが、
どう手を付けていいのかわからないのでご教授願います。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問