”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何从 Spring Data JPA GROUP BY 查询返回自定义对象?

如何从 Spring Data JPA GROUP BY 查询返回自定义对象?

发布于2024-12-22
浏览:771

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

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

简介


检索将数据作为来自 Spring Data JPA GROUP BY 查询的自定义对象增强了数据表示并简化了进一步处理。本指南探讨了如何实现这一目标,展示了 JPQL 和本机查询的解决方案。

JPQL 查询


JPA 规范中的 JPQL 查询提供本机查询支持返回自定义对象。

第 1 步:创建自定义 Bean


定义一个简单的 Bean表示所需输出结构的类:

public class SurveyAnswerStatistics {
  private String answer;
  private Long cnt;

  // Constructor
}

第 2 步:返回 Bean 实例


更新存储库方法以返回自定义 Bean 的实例:

public interface SurveyRepository extends CrudRepository {
    @Query("SELECT new com.path.to.SurveyAnswerStatistics(v.answer, COUNT(v)) FROM Survey v GROUP BY v.answer")
    List findSurveyCount();
}

原生查询


虽然原生查询缺乏对 new 关键字的直接支持,但 Spring Data Projection 接口提供了替代解决方案:

第 1 步:定义投影接口


创建一个投影接口,其属性与所需的属性相对应输出:

public interface SurveyAnswerStatistics {
  String getAnswer();
  int getCnt();
}

第 2 步:返回投影属性


更新存储库方法以返回投影属性:

public interface SurveyRepository extends CrudRepository {
    @Query(nativeQuery = true, value =
            "SELECT v.answer AS answer, COUNT(v) AS cnt FROM Survey v GROUP BY v.answer")
    List findSurveyCount();
}

使用 SQL AS 关键字将结果字段无缝映射到投影属性。

最新教程 更多>
  • 极简密码管理器桌面应用程序:进军 Golang 的 Wails 框架(第 2 部分)
    极简密码管理器桌面应用程序:进军 Golang 的 Wails 框架(第 2 部分)
    Hi again, coders! In the first part of this short series we saw the creation and operation of a desktop application to store and encrypt our passwords...
    编程 发布于2024-12-23
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-12-23
  • 插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2024-12-23
  • ES6 React 组件:何时使用基于类与函数式?
    ES6 React 组件:何时使用基于类与函数式?
    在 ES6 基于类和函数式 ES6 React 组件之间做出选择使用 React 时,开发人员面临着使用 ES6 基于类的选择组件或功能 ES6 组件。了解每种类型的适当用例对于最佳应用程序开发至关重要。函数式 ES6 组件:无状态和简单函数式组件是无状态的,这意味着它们不维护任何内部状态。他们只是...
    编程 发布于2024-12-23
  • 如何在 PHP 中找到两个平面数组之间的唯一值?
    如何在 PHP 中找到两个平面数组之间的唯一值?
    在平面数组之间查找唯一值给定两个数组,任务是确定仅存在于其中一个数组中的值。此操作通常称为查找两个集合之间的差异。在 PHP 中,您可以利用 array_merge、array_diff 和 array_diff 函数来实现此操作。详细解法如下:$array1 = [64, 98, 112, 92,...
    编程 发布于2024-12-23
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-12-23
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-12-23
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-12-23
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2024-12-23
  • CSS 可以在内联块元素中本机插入换行符吗?
    CSS 可以在内联块元素中本机插入换行符吗?
    CSS 在行内块元素中插入换行符:理论探索在不断发展的 Web 开发领域,这种能力操纵内容流仍然是最重要的。经常出现的一个特殊挑战涉及在内联块元素中插入换行符。考虑以下 HTML 结构:<h3 id="features">Features</h3> <...
    编程 发布于2024-12-23
  • 如何在 PHP 中轻松转换时区之间的时间和日期?
    如何在 PHP 中轻松转换时区之间的时间和日期?
    在 PHP 中转换时区之间的时间和日期使用 PHP,您可以轻松地在不同时区之间转换时间和日期。此功能在处理全球数据的应用程序或与来自不同位置的用户一起工作时特别有用。获取时区偏移量要获取与 GMT 的时间偏移量,您可以使用 DateTimeZone 类。它提供了时区及其各自偏移量的完整列表。$tim...
    编程 发布于2024-12-23
  • HTML 格式标签
    HTML 格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2024-12-23
  • 如何在Windows上安装和使用Pip进行Python包管理?
    如何在Windows上安装和使用Pip进行Python包管理?
    Pip:在 Windows 上安装 Python 包的轻松方式在 Windows 上安装 Python 包可能是一项艰巨的任务,特别是如果您在使用 EasyInstall 时遇到困难。幸运的是,EasyInstall 的后继者 Pip 提供了更加简化和简化的解决方案。在 Windows 上逐步安装 ...
    编程 发布于2024-12-23
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-23
  • 如何在Python的`type()`和`isinstance()`之间进行选择以进行对象类型检查?
    如何在Python的`type()`和`isinstance()`之间进行选择以进行对象类型检查?
    如何确定对象的类型确定对象的类型对于保证数据一致性并相应地执行操作至关重要。 Python 为此目的提供了两个内置函数:type() 和 isinstance()。使用 type()type() 函数返回确切的类型一个物体的。例如:>>> type([]) is list True...
    编程 发布于2024-12-23

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3