>데이터 베이스 >MySQL 튜토리얼 >JDBC에서 IN 절을 효율적으로 매개변수화하는 방법은 무엇입니까?

JDBC에서 IN 절을 효율적으로 매개변수화하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-15 10:51:44176검색

How to Efficiently Parameterize IN Clauses in JDBC?

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, 이름, 값을 선택하세요.";

공개 목록 find(Set ids)에서 SQLException이 발생합니다. 목록 엔터티 = new ArrayList<>(); 문자열 sql = String.format(SQL_FIND, preparePlaceHolders(ids.size()));

<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>

위 내용은 JDBC에서 IN 절을 효율적으로 매개변수화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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