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

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정
