JPA에서 기본 쿼리 결과를 POJO 클래스 컬렉션으로 변환하는 방법
JPA로 작업할 때 기본 쿼리를 실행해야 하는 경우가 있습니다. JPA 기준 쿼리를 사용하여 효율적으로 검색할 수 없는 데이터에 액세스합니다. 기본 쿼리의 결과가 값 모음인 경우 추가 처리를 위해 각 결과 객체를 POJO(Plain Old Java Object) 클래스로 변환해야 할 수도 있습니다.
매핑을 사용한 직접 캐스팅 엔터티
JPA 2.0 이하에서는 기본 쿼리 결과를 POJO 클래스로 직접 캐스팅하는 것이 불가능했습니다. 그러나 JPA 2.1에서는 기본 쿼리 결과를 POJO에 매핑할 수 있는 @SqlResultSetMapping 주석을 도입했습니다.
이 기능을 사용하려면 엔터티 클래스에 @SqlResultSetMapping 주석을 정의해야 합니다. 결과는 클래스의 속성에 해당하는 열과 매핑되어야 합니다. 예:
@SqlResultSetMapping( name = "JediResult", classes = { @ConstructorResult(targetClass = Jedi.class, columns = {@ColumnResult(name = "name"), @ColumnResult(name = "age")}) } )
이 주석을 사용하면 기본 쿼리를 실행하고 @SqlResultSetMapping 주석을 사용하여 POJO 클래스에 대한 매핑을 지정할 수 있습니다.
Query query = em.createNativeQuery("SELECT name, age FROM jedi_table", "JediResult"); @SuppressWarnings("unchecked") List<Jedi> jedis = query.getResultList();
수동 매핑을 사용한 간접 캐스팅
JPA 2.1을 사용할 수 없는 경우 리플렉션을 사용하여 기본 쿼리 결과를 POJO에 수동으로 매핑하는 것이 가능합니다. 여기에는 튜플 배열(네이티브 쿼리에서 반환됨)과 POJO 클래스를 입력으로 사용하고 리플렉션을 사용하여 튜플의 값으로 POJO 클래스의 인스턴스를 만드는 메서드를 만드는 작업이 포함됩니다. 그런 다음 이 방법을 사용하여 각 결과를 POJO 개체에 매핑할 수 있습니다.
명명된 기본 쿼리 사용
기본 쿼리 결과를 POJO로 변환하는 또 다른 옵션은 명명된 기본 쿼리를 사용하는 것입니다. 기본 쿼리. 명명된 기본 쿼리를 사용하면 엔터티 클래스에서 기본 쿼리를 정의하고 쿼리에 대한 결과 클래스를 지정할 수 있습니다. 이 결과 클래스는 POJO 또는 엔터티 클래스일 수 있습니다. 명명된 기본 쿼리를 사용하면 리플렉션을 사용하지 않고 결과를 POJO 클래스에 직접 매핑할 수 있습니다.
위 내용은 기본 쿼리 결과를 JPA의 POJO 클래스 컬렉션으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!