Heim >Java >javaLernprogramm >Wie gebe ich benutzerdefinierte Objekte in Spring Data JPA GROUP BY-Abfragen zurück?

Wie gebe ich benutzerdefinierte Objekte in Spring Data JPA GROUP BY-Abfragen zurück?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-01 14:30:02551Durchsuche

How to Return Custom Objects in Spring Data JPA GROUP BY Queries?

Benutzerdefinierte Objektrückgabe in Spring Data JPA GROUP BY-Abfragen

Spring Data JPA bietet eine bequeme Möglichkeit, Datenbankoperationen mithilfe von JPQL (Java Persistence) durchzuführen Abfragesprache). Wenn Sie eine benutzerdefinierte JPQL-Abfrage mit einer GROUP BY-Klausel verwenden, möchten Sie möglicherweise benutzerdefinierte Objekte anstelle der integrierten SQL-Ergebnisarrays zurückgeben.

JPQL-Lösung

  1. Definieren Sie eine einfache Bean-Klasse:
<code class="java">public class SurveyAnswerStatistics {
    private String answer;
    private Long count;
    ... // getters and setters
}</code>
  1. Bean-Instanzen aus der Repository-Methode zurückgeben:
<code class="java">@Query("SELECT new com.path.to.SurveyAnswerStatistics(v.answer, COUNT(v)) FROM Survey v GROUP BY v.answer")
public List<SurveyAnswerStatistics> findSurveyCount();</code>

Native Query Solution

Für native Abfragen werden Spring Data Projection-Schnittstellen anstelle von Bean-Klassen verwendet:

  1. Definieren Sie eine Projektionsschnittstelle:
<code class="java">public interface SurveyAnswerStatistics {
    String getAnswer();
    int getCnt();
    ... // additional getters
}</code>
  1. Projizierte Eigenschaften aus der Abfrage zurückgeben:
<code class="java">@Query(nativeQuery = true, value = "SELECT v.answer AS answer, COUNT(v) AS cnt FROM Survey v GROUP BY v.answer")
public List<SurveyAnswerStatistics> findSurveyCount();</code>

Wichtige Hinweise

  • Verwenden Sie einen vollständig qualifizierten Pfad zur Bean-Klasse.
  • Rufen Sie den Bean-Konstruktor mit dem neuen Schlüsselwort auf.
  • Übergeben Sie Attribute in derselben Reihenfolge wie die Bean-Konstruktor-Parameter.
  • Stellen Sie sicher, dass die Abfrage eine gültige JPA-Abfrage ist.
  • Verwenden Sie das SQL-AS-Schlüsselwort für eine eindeutige Zuordnung, wenn Sie native Abfragen verwenden.

Das obige ist der detaillierte Inhalt vonWie gebe ich benutzerdefinierte Objekte in Spring Data JPA GROUP BY-Abfragen zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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