"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > JDBC에서 IN 절을 효과적으로 매개변수화하려면 어떻게 해야 합니까?

JDBC에서 IN 절을 효과적으로 매개변수화하려면 어떻게 해야 합니까?

2024-11-02에 게시됨
검색:564

How can I parameterize an IN clause in JDBC effectively?

JDBC IN 절 매개변수화: 효율적인 접근 방식

IN 절 쿼리를 처리할 때(예: SELECT * FROM MYTABLE WHERE MYCOL in ( ?), 인수를 매개변수화하면 보안과 효율성이 보장됩니다. JDBC는 직접적인 솔루션을 제공하지 않지만 특정 드라이버는 preparedStatement#setArray()를 지원할 수 있습니다.

매개변수화를 위한 도우미 메서드

직접 지원이 없는 경우 도우미 메서드를 활용하여 IN 절에 대한 자리 표시자를 생성하고 값을 동적으로 설정할 수 있습니다.

  • preparePlaceHolders(int length): 지정된 길이의 자리 표시자의 쉼표로 구분된 목록을 생성합니다.
  • setValues(PreparedStatement prepareStatement, Object... 값): preparedStatement#setObject()를 사용하여 루프에 값을 설정합니다.

구현 예

다음 데이터 액세스 방법을 고려하십시오.

private static final String SQL_FIND = "SELECT id, name, value FROM entity WHERE id IN (%s)";

public List find(Set ids) throws SQLException {
    List entities = new ArrayList();
    String sql = String.format(SQL_FIND, preparePlaceHolders(ids.size()));

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

주요 고려 사항

  • 데이터베이스는 IN 절에 허용되는 값의 수를 제한할 수 있습니다.
  • 이 접근 방식은 다양한 데이터베이스 간의 이식성을 보장합니다. 값 설정에서 SQL 문 생성을 분리하여 수행합니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3