>데이터 베이스 >MySQL 튜토리얼 >여러 값이 있는 JPQL의 IN 절을 효율적으로 사용하려면 어떻게 해야 합니까?

여러 값이 있는 JPQL의 IN 절을 효율적으로 사용하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-30 18:10:101021검색

How Can I Efficiently Use JPQL's IN Clause with Multiple Values?

JPQL IN 절 확장: 목록 및 컬렉션 활용

JPQL은 특정 값 집합을 기반으로 엔터티를 필터링하는 IN 절을 제공합니다. 그러나 임의 개수의 값이 포함된 시나리오의 경우 각 매개 변수를 명시적으로 지정하는 것은 지루하고 비효율적일 수 있습니다. 이 기사에서는 배열, 목록 또는 집합과 같은 컨테이너를 사용하여 IN 절의 값을 확장할 수 있는 가능성을 살펴봅니다.

질문에 직접 답하기 위해 JPQL 2.0에서는 컬렉션을 IN 절에 매개변수로 전달하는 지원을 도입했습니다. 이렇게 하면 각 값을 수동으로 지정할 필요가 없고 코드 구조가 단순화됩니다.

다음 Java 코드는 목록을 사용하여 이 기능을 보여줍니다.

String qlString = "select item from Item item where item.name IN :names";
Query q = em.createQuery(qlString, Item.class);

List<String> names = Arrays.asList("foo", "bar");

q.setParameter("names", names);
List<Item> actual = q.getResultList();

assertNotNull(actual);
assertEquals(2, actual.size());

EclipseLink가 이 구문을 지원한다는 점은 주목할 가치가 있습니다. , Hibernate 3.5.1에서는 매개변수를 괄호로 묶어야 합니다(알려진 버그).

위 내용은 여러 값이 있는 JPQL의 IN 절을 효율적으로 사용하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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