首頁 > Java > java教程 > 如何在 Spring Data JPA GROUP BY 查詢中傳回自訂物件?

如何在 Spring Data JPA GROUP BY 查詢中傳回自訂物件?

Mary-Kate Olsen
發布: 2024-11-01 14:30:02
原創
544 人瀏覽過

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

Spring Data JPA GROUP BY 查詢中的自訂物件回傳

Spring Data JPA 提供了一種使用JPQL(Java PJavaers資料庫操作的便捷方法查詢語言)。當使用 GROUP BY 子句的自訂 JPQL 查詢時,您可能想要傳回自訂物件而不是內建 SQL 結果陣列。

JPQL 解決方案

  1. 定義一個簡單的Bean 類別:
<code class="java">public class SurveyAnswerStatistics {
    private String answer;
    private Long count;
    ... // getters and setters
}</code>
登入後複製
  1. 從儲存庫方法傳回Bean 實例:
<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>
登入後複製

原生查詢解決方案

對於本機查詢,使用Spring Data Projection 介面而不是bean 類別:

對於本機查詢,使用Spring Data Projection 介面而不是bean 類別:
  1. 定義投影介面:
<code class="java">public interface SurveyAnswerStatistics {
    String getAnswer();
    int getCnt();
    ... // additional getters
}</code>
登入後複製
  1. 從查詢回傳投影屬性:
<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>
登入後複製

重要說明🎜>

  • 使用Bean 類別的完全限定路徑。
  • 使用 new 關鍵字呼叫 bean 建構子。
  • 依照與 bean 建構子參數相同的順序傳遞屬性。
  • 確保查詢是有效的 JPA 查詢。
  • 使用本機查詢時,使用 SQL AS 關鍵字進行明確對應。

以上是如何在 Spring Data JPA GROUP BY 查詢中傳回自訂物件?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板