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 중국어 웹사이트의 기타 관련 기사를 참조하세요!