IN 절 매개변수와 함께 ReadyStatement 사용
질문:
PreparedStatement를 어떻게 채울 수 있나요? IN 절에 매개변수 목록이 있는 JDBC 명령문이 있습니까? 이는 매개변수 목록을 미리 알 수 없는 경우 특히 중요합니다.
해결책:
여러 값을 사용하여 IN 절을 동적으로 구성하려면 다음 단계를 따르세요.
var stmt = String.format("select * from test where field in (%s)", values.stream() .map(v -> "?") .collect(Collectors.joining(", ")));
PreparedStatement pstmt = connection.prepareStatement(stmt);
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!