>Java >java지도 시간 >기본 쿼리 결과를 JPA의 POJO 클래스 컬렉션으로 변환하는 방법은 무엇입니까?

기본 쿼리 결과를 JPA의 POJO 클래스 컬렉션으로 변환하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-14 02:16:10399검색

How to Convert Native Query Results to POJO Class Collections in JPA?

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

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