>Java >java지도 시간 >JDBC에서 동적 IN 절 매개변수와 함께 ReadyStatements를 사용하는 방법은 무엇입니까?

JDBC에서 동적 IN 절 매개변수와 함께 ReadyStatements를 사용하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-16 03:42:10708검색

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

IN 절 매개변수와 함께 ReadyStatement 사용

질문:

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부터 하나씩:
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 절 매개변수와 함께 ReadyStatements를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.