Heim > Java > javaLernprogramm > Wie konvertiert man native JPA-Abfrageergebnisse effizient in POJO-Sammlungen?

Wie konvertiert man native JPA-Abfrageergebnisse effizient in POJO-Sammlungen?

Linda Hamilton
Freigeben: 2024-12-09 11:13:06
Original
1089 Leute haben es durchsucht

How to Efficiently Convert JPA Native Query Results to POJO Collections?

Lösung der Ergebniskonvertierung von JPA-Sammlungsabfragen mit POJO-Klassen

Bei der Arbeit mit JPA stoßen wir häufig auf Szenarien, in denen eine native Abfrage eine Ergebnismenge zurückgibt mit mehreren Spalten. Die Konvertierung dieser Ergebnismenge in eine Sammlung von POJO-Klassen ist für die Verarbeitung der Daten unerlässlich. In diesem Artikel befassen wir uns mit verschiedenen Ansätzen, um diese Konvertierung zu erreichen.

Verwendung von zugeordneten Entitäten (JPA 2.0 und höher)

JPA 2.0 führt die Möglichkeit ein, native Abfragen abzubilden Ergebnisse in eine JPA-Entitätsklasse. Dieser Ansatz ist einfach und unkompliziert:

Query query = em.createNativeQuery("SELECT name,age FROM jedi_table", Jedi.class);
List<Jedi> items = (List<Jedi>) query.getResultList();
Nach dem Login kopieren

Dieser Ansatz erfordert jedoch, dass Jedi eine zugeordnete Entitätsklasse ist, was möglicherweise nicht immer wünschenswert ist.

Manuelle Zuordnung

Für Szenarien, in denen die Verwendung zugeordneter Entitäten nicht geeignet ist, können wir auf manuelle Zuordnung zurückgreifen. Dazu gehört das Erstellen einer Dienstprogrammmethode, um das Ergebnistupel einem POJO-Klassenkonstruktor zuzuordnen.

public static <T> T map(Class<T> type, Object[] tuple) {
    Constructor<T> ctor = type.getConstructor(...); // Using reflection to find the constructor
    return ctor.newInstance(tuple);
}
Nach dem Login kopieren

Mit der manuellen Zuordnung können wir eine Liste von Tupeln einfach in eine POJO-Sammlung konvertieren:

Query query = em.createNativeQuery("SELECT name,age FROM jedi_table");
@SuppressWarnings("unchecked")
List<Object[]> records = query.getResultList();
List<Jedi> jedis = new LinkedList<>();
for (Object[] record : records) {
    jedis.add(map(Jedi.class, record));
}
Nach dem Login kopieren

JPA 2.1 mit @SqlResultSetMapping

JPA 2.1 bietet die Annotation @SqlResultSetMapping, die eine elegantere Möglichkeit bietet, native Abfrageergebnisse POJO-Klassen zuzuordnen. Diese Annotation wird in einer Entität deklariert:

@SqlResultSetMapping(name="JediResult", classes = {
    @ConstructorResult(targetClass = Jedi.class, 
    columns = {@ColumnResult(name="name"), @ColumnResult(name="age")})
})
Nach dem Login kopieren

Mithilfe dieser Zuordnung können wir die Ergebnismenge direkt in eine POJO-Sammlung konvertieren:

Query query = em.createNativeQuery("SELECT name,age FROM jedi_table", "JediResult");
@SuppressWarnings("unchecked")
List<Jedi> samples = query.getResultList();
Nach dem Login kopieren

Mit XML-Zuordnung

Alternativ können wir die Annotation @SqlResultSetMapping im definieren orm.xml-Datei und hält sie aus der Entitätsklasse heraus:

<named-native-query name="GetAllJedi" result-set-mapping="JediMapping">
    <query>SELECT name,age FROM jedi_table</query>
</named-native-query>

<sql-result-set-mapping name="JediMapping">
    <constructor-result target-class="org.answer.model.Jedi">
        <column name="name" class="java.lang.String" />
        <column name="age" class="java.lang.Integer" />
    </constructor-result>
</sql-result-set-mapping>
Nach dem Login kopieren

Mithilfe dieser XML-Zuordnung können wir die Konvertierung wie folgt durchführen:

Query query = em.createNativeQuery("GetAllJedi");
@SuppressWarnings("unchecked")
List<Jedi> samples = query.getResultList();
Nach dem Login kopieren

Jeder dieser Ansätze hat seine eigenen eigene Vor- und Nachteile. Die Wahl der richtigen Methode hängt von den spezifischen Anforderungen und Einschränkungen der Anwendung ab.

Das obige ist der detaillierte Inhalt vonWie konvertiert man native JPA-Abfrageergebnisse effizient in POJO-Sammlungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage