집 >데이터 베이스 >MySQL 튜토리얼 >JDBC에서 IN 절을 효율적으로 매개변수화하는 방법은 무엇입니까?
JDBC의 IN 절 매개변수화: 직접적인 방법이 있나요?
JDBC에서는 IN 절을 효율적으로 매개변수화하는 것이 어려울 수 있습니다. 일반적인 쿼리 구조는 다음과 같습니다.
<code class="language-sql">SELECT * FROM MYTABLE WHERE MYCOL in (?)</code>
이와 같은 절에 값을 동적으로 삽입하려면 SQL을 변경하지 않고 다양한 데이터베이스에서 작동하는 간단한 방법이 필요합니다.
안타깝게도 JDBC는 이 문제에 대한 기본 솔루션을 제공하지 않습니다. 그러나 일부 드라이버는 IN 절에 대해 ReadyStatement#setArray()를 지원할 수 있습니다.
대체 방법
또는 도우미 메서드를 사용하여 자리 표시자를 만들고 매개변수 값을 반복적으로 설정할 수 있습니다. 구현은 다음과 같습니다.
<code class="language-java">public static String preparePlaceHolders(int length) { return String.join(",", Collections.nCopies(length, "?")); } public static void setValues(PreparedStatement preparedStatement, Object... values) throws SQLException { for (int i = 0; i < values.length; i++) { preparedStatement.setObject(i + 1, values[i]); } }</code>
사용 예:
``자바 private static final String SQL_FIND = "WHERE id IN (%s) 엔터티에서 ID, 이름, 값을 선택하세요.";공개 목록 } 위 내용은 JDBC에서 IN 절을 효율적으로 매개변수화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!<code>try (
Connection connection = dataSource.getConnection();
PreparedStatement statement = connection.prepareStatement(sql);
) {
setValues(statement, ids.toArray());
try (ResultSet resultSet = statement.executeQuery()) {
while (resultSet.next()) {
entities.add(map(resultSet));
}
}
}
return entities;</code>
<code>
<p><strong>注意事项</strong></p>
- 请注意,某些数据库限制了IN子句中允许的值的数量。
- 此方法利用PreparedStatement接口,确保跨数据库兼容性。
- 还必须考虑数据库特定的优化,例如使用数组或批量更新。</code>