搜索
首页Javajava教程如何在 Spring Data JPA GROUP BY 查询中返回自定义对象?

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

Spring Data JPA GROUP BY 查询中的自定义对象返回

Spring Data JPA 提供了一种使用 JPQL(Java Persistence)执行数据库操作的便捷方法查询语言)。当使用带有 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();</surveyanswerstatistics></code>

原生查询解决方案

对于本机查询,使用 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();</surveyanswerstatistics></code>

重要说明

  • 使用 Bean 类的完全限定路径。
  • 使用 new 关键字调用 bean 构造函数。
  • 按照与 bean 构造函数参数相同的顺序传递属性。
  • 确保查询是有效的 JPA 查询。
  • 使用本机查询时,使用 SQL AS 关键字进行明确映射。

以上是如何在 Spring Data JPA GROUP BY 查询中返回自定义对象?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具