Beim Ausführen einer SQL-Abfrage mit einer IN-Klausel unter Verwendung von PreparedStatement von JDBC kann das Festlegen der Werte für mehrere Parameter eine Herausforderung sein.
Handhabung vorbestimmt Parameter
Wenn die Liste der Parameter vorher bekannt ist, verwenden Sie den folgenden Ansatz:
Umgang mit unbekannten Parametern
Wenn die Liste der Parameter vorher nicht bekannt ist, verwenden Sie die folgenden Schritte:
Zum Beispiel, um die Parameter für die Abfrage festzulegen Wählen Sie * aus dem Testfeld in (?) mit mehreren Werten aus. Sie können den folgenden Code verwenden:
String query = String.format("select * from test where field in (%s)", values.stream() .map(v -> "?") .collect(Collectors.joining(", "))); PreparedStatement stmt = connection.prepareStatement(query); int index = 1; for (Object o : values) { stmt.setObject(index++, o); }
Dieser Ansatz stellt sicher, dass die IN-Klausel dynamisch eine beliebige Anzahl von Parametern aufnehmen kann, was eine flexible Abfrageausführung ermöglicht .
Das obige ist der detaillierte Inhalt vonWie kann PreparedStatement mit einer IN-Klausel für mehrere Parameter in JDBC effizient verwendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!