
No.4ベストアンサー
- 回答日時:
Statement, PreparedStatement, CallableStatement で用意されている
execute(String), execute()はステートメントの種類によってアプローチが
違うだけで、やってることはすべて同じですよ。
なので、どのように実行されるのかとどういう結果が得られるのか、という説明は文章の言い回しの違いはあれど、内容は一緒です。
https://docs.oracle.com/javase/jp/21/docs/api/ja …
https://docs.oracle.com/javase/jp/21/docs/api/ja …
CallableStatement::execute()は、PreparedStatement::execute()からの継承。
だから補足のコードでもgetResultSet()をわざわざ呼んでますよね。
まぁ、テストコードを書いたり、まずは結果セットの取得可否をboolを受けた後に何かを判断する必要がある、というシーンではexecute(), getResultSet()を使ってもいいんですが、特別な理由がないのにわざわざ使う必要がありません。
execute(), getResultSet()を利用するのが基準ではなく、特別な理由がある場合に限ってはそういう書き方をする、がベターです。
例えばローコードツールみたいなものを作っていたとして、ユーザーが任意で指定したSQLを実行するアクションがあった時、ツール側としては結果をどのように受け取りたいかをユーザーに指示してもらわないとそのSQLが何を求めたいのかわからない、とかそういうシチュエーションとかですかね。
内部実装として求める結果が当然定まっている時に利用するものではありません。
また、補足のコードでは、その実行が横行すると、前回私が指摘したような懸念点が顕在化します。
Statementを利用する時は、パラメーターが必要ないSQLを発行する時、
PreparedStatementを利用する時は、パラメーターが必要なSQLを発行する時、
CallableStatementを利用する時は、ストアドプロシージャ―を発行する時
です。
しかし、Statementを利用することは特別な理由がない限り避けた方がよいです。
例えばSQL文の文字列を動的に組み立ててSQLを発行する時にStatementは利用できます。
しかし、ある動的に変化する条件の値などをSQL文の文字列にそのまま組み立てると、SQLインジェクションの温床になります。
そういった問題もある中で、プリペアドステートメントというが概念があります。
そういうことがなければ別に使ってもいいんですが、わざわざパラメーターがあるか/ないかで利用するステートメントの種類を変える必然性がありません。
ストアドプロシージャの実行でないなら、それこそこれはPreparedStatementで一本化していいのです。
パラメーターがなければ指定しなければいいだけですからね。
脆弱性を生み出してしまうかもしれないアプローチを許容する必要性がありません。
このことから、よほど特別な理由がない限り、Connection::createStatement()を利用するシーンは出てこないと思います。
execute()の利用意義はともかくとして、例えば補足と前回回答のお礼にあるコードをベースにすると、下記でいいのです。
private ResultSet dtbs(Connection cnnctn,String sql)
{
ResultSet rs = null;
try
{
PreparedStatement ps = cnnctn.prepareStatement(sql);
if(ps.execute())rs=ps.getResultSet();
}
catch(SQLException e)
{
System.err.println(e);
}
return rs;
}
SQLを実行したい時はConnection::prepareStatement()を利用すればいいし、ストアドプロシージャを実行したい時はConnection::prepareCall()を利用すればいいのです。
No.3
- 回答日時:
> resultsetを返すメソッドで使いたいのでexecuteだと
> getresultsetを使わないといけないので手間が増えます
ですよね。
ですからそもそもResultSetを求めるのが明白ならexecuteQuery()を利用すべきで、
そうでない場合はexecuteUpdate()を利用すべきです。
なんだか分からないけどとりあえず実行する、という発想なら
execute()を実行することと、やってることが変わらないんです。
目的が違うのだから、命令も異なるのは自然なことです。
品質を悪化させるから、目的の異なる命令アプローチを一本化する意義がありません。
例えばINSERTを発行しただけなのに、自分が何しているかもよく分かっておらず、
でも結果はResultSetオブジェクトを受け取るから、それを何か操作できるようだ、
という誤解を生み、誤ったオブジェクト操作を誘発させます。
独自のラッパークラスでも用意してそこで判断して、独自の結果クラスでも返却するなら別ですが。
まぁ結果的にどうしたいかはご自由にどうぞですが、個人的にはその一本化する方法論をおすすめすることはありません。
private void dtbsx(Connection cnnctn,String sql)
{
ResultSet rs = null;
try
{
PreparedStatement ps = cnnctn.prepareStatement(sql);
ps.executeUpdate();
}
catch(SQLException e)
{
System.err.println(e);
}
}
ご意見を参考に
結局、妥協してdtbsとdtbsxの2メソッドでやることにしました
selectのときdtbsを使いinsert等々のときdtbsxを使うことにしました
No.2
- 回答日時:
> 使い分ける面倒を回避するためには
> エラーがでて気持ち悪いけれど実害がないのでexecuteQuery一本で行く
> しかない様ですね
そのような考えであれば、execute()でも実行はできます。
https://docs.oracle.com/javase/jp/8/docs/api/jav …
ただし、自分が求めているものが明白な時に利用するものではありません。
戻り値の結果となる可能性が混在して考えられる場合には利用するかもしれませんが、条件が揃わないとそのようなことは起こりません。
execute()を利用する場合は、自分で求めることを把握した上で二度手間の命令呼び出しが必要になります。
(レコードセットや影響件数を別個で求める必要がある)
本来、求めることが明白なのだから、そこにマッチする命令を利用すべきです。
private ResultSet dtbs(Connection cnnctn,String sql)
{
ResultSet rs = null;
try
{
PreparedStatement ps = cnnctn.prepareStatement(sql);
rs = ps.executeQuery();
}
catch(SQLException e)
{
System.err.println(e);
}
return rs;
}
resultsetを返すメソッドで使いたいのでexecuteだと
getresultsetを使わないといけないので手間が増えます
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 下の画像はSQLの4大命令の性質をまとめたものであるらしいです UPDATE INSERT DELE 1 2023/06/07 15:36
- PHP php エラー 2 2022/10/23 16:43
- SQL Server AccessのInsertクエリのあとつづけてDeleteクエリを行いたいがSQLでどう書いたらいい 3 2023/05/27 14:12
- MySQL (初心者)MySQLやmaraDBで、create table して作るカラム名を英語表記にしている 2 2024/07/18 07:58
- PHP php エラー 3 2022/11/18 23:32
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- UNIX・Linux Linuxの実行結果を修正したいです。 6 2022/11/22 12:57
- MySQL 次の時間帯の勝率の合計を求めるSQL文 1 2023/07/04 17:12
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
このQ&Aを見た人はこんなQ&Aも見ています
-
プログラミング言語について
その他(プログラミング・Web制作)
-
ネットワークフォルダの中身をクリアするbatの記述を教えてください。
その他(プログラミング・Web制作)
-
Visualbasicの現状について教えてください
Visual Basic(VBA)
-
-
4
長門有希のようにコンピュータに詳しい女性っているのでしょうかよろしくお願いしますm(_ _)m
その他(プログラミング・Web制作)
-
5
近年誕生したプログラミング言語
その他(プログラミング・Web制作)
-
6
OSS(オープンソースソフトウェア)のライセンスについて簡易に書かれている本やサイトについて
オープンソース
-
7
Web画面の文字をVB6で取得したい
Visual Basic(VBA)
-
8
AIのプログラムについて教えてください
その他(プログラミング・Web制作)
-
9
プログラミングについて プログラミングの練習(勉強)ができるようなサイトなどありませんか? あれば教
その他(プログラミング・Web制作)
-
10
プログラミングの進学について
その他(プログラミング・Web制作)
-
11
【ExcelVBA】5万行以上のデータ比較の効率的な処理方法について
Visual Basic(VBA)
-
12
検索1位なのに依頼がない
SEO
-
13
フロントエンドエンジニアをしていますが、スキルアップのための転職、異動は3年目では早すぎますか? 今
その他(プログラミング・Web制作)
-
14
Cのプログラムからアクセスできないファイル名の一括変更方法
C言語・C++・C#
-
15
検索エンジンはなくなる?
SEO
-
16
Excelのマクロについて教えてください。
Visual Basic(VBA)
-
17
IT業で開発をされてる方々に質問なんですが、一日に書かれるコード数ってどれくらいですか? また、最近
その他(プログラミング・Web制作)
-
18
VB.net 文字列から日付型へ変更したい
Visual Basic(VBA)
-
19
HTML CSSの勉強のポートフォリオを作りたいんですが、どうしたらいいですか?
HTML・CSS
-
20
ホログラムを作ってくれる会社はありませんか
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
サーブレットからBeanを呼び出...
-
Javascriptのパーミッション
-
eclipse で実行時のコマンドを...
-
split関数で区切り文字がない場合
-
コンストラクタの処理と参照が...
-
java macとwindowsの互換
-
ストアドプロシージャ呼び出し...
-
Worksheet_Changeが動かない
-
eclipseでスタックサイズを変更...
-
javaアプリケーションをH...
-
eclipseでは動くのにブラウザで...
-
printfの小数点以下の表示桁数...
-
Eclipseプログラム引数の変数指定
-
アプレットの初期化されていま...
-
jdbcでinsert,delete,createをe...
-
Javascriptの値をJava(JSP)へ渡...
-
ファイルの指定について
-
「ワークスペースをビルド中」...
-
エクリプスで実行時、最新クラ...
-
マイクラjavaでForgeを入れたい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「ワークスペースをビルド中」...
-
split関数で区切り文字がない場合
-
eclipseでスタックサイズを変更...
-
Eclipse(JAVA)のデバッグで他...
-
Javascriptの値をJava(JSP)へ渡...
-
コミット前の更新データをチェ...
-
JAVAにのeclipseに関する質問で...
-
Javaで年月の取得(YYYYMM形式で)
-
エクリプスで実行時、最新クラ...
-
Eclipse 実行→Javaアプリケー...
-
Eclipseで実行>Javaアプリケー...
-
javascriptで、style undefined...
-
jdbcでinsert,delete,createをe...
-
Javascriptのパーミッション
-
jasper.exceptionとは?
-
JUnit コードカバレッジについて
-
jarsigner 署名確認について
-
バイナリーコードと、ソースコ...
-
JAVAでアプレットのエラー(ecl...
-
環境変数設定で
おすすめ情報
private ResultSet dtbs(Connection cnnctn,String sql)
{
ResultSet rs=null;
try
{
Statement stmt=cnnctn.createStatement();
if(stmt.execute(sql))rs=stmt.getResultSet();
}
catch(SQLException e)
{
System.err.println(e);
}
return rs;
}
stmt.execute(sql)が正解でした
これ一本でいけることがわかりました