ホームページ > Java > &#&チュートリアル > JDBC で動的 IN 句パラメータで PreparedStatement を使用するにはどうすればよいですか?

JDBC で動的 IN 句パラメータで PreparedStatement を使用するにはどうすればよいですか?

Patricia Arquette
リリース: 2024-12-16 03:42:10
オリジナル
707 人が閲覧しました

How to Use PreparedStatements with Dynamic IN Clause Parameters in JDBC?

IN 句パラメータで PreparedStatement を使用する

質問:

準備されたステートメントをどのように設定できますかIN 句にパラメータのリストを含む JDBC ステートメント?これは、パラメータのリストが事前にわからない場合に特に重要です。

解決策:

複数の値を含む IN 句を動的に構築するには、次の手順に従います。

  1. 疑問符を使用して、IN 句の各値のプレースホルダーを作成します(?):
var stmt = String.format("select * from test where field in (%s)",
                         values.stream()
                         .map(v -> "?")
                         .collect(Collectors.joining(", ")));
ログイン後にコピー
  1. 構築された文字列を使用してステートメントを準備します:
PreparedStatement pstmt = connection.prepareStatement(stmt);
ログイン後にコピー
  1. IN 句に値を設定します。インデックス 1 から 1 つずつ:
int index = 1;
for (Object o : values) {
    pstmt.setObject(index++, o); // Replace with appropriate data type
}
ログイン後にコピー

このアプローチ複数のパラメータまたは不明なパラメータを動的に処理できます。

StringBuilder を使用した代替ソリューション:

List<String> values = ...;
StringBuilder builder = new StringBuilder();

for (int i = 0; i < values.size(); i++) {
    builder.append("?,");
}

String placeHolders = builder.deleteCharAt(builder.length() - 1).toString();
String stmt = "select * from test where field in (" + placeHolders + ")";
ログイン後にコピー

上記と同じ手順に従ってステートメントを準備し、値を設定します.

以上がJDBC で動的 IN 句パラメータで PreparedStatement を使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート