从 JPQL 查询返回 JPA 实体的子集作为映射数组?

2024-03-03

在 JPQL 中,可以使用构造函数表达式来请求实体的子集,例如

SELECT NEW example.EmployeeDetails(e.name, e.salary, e.department.name) FROM Employee e

它返回 EmployeeDetails 类型的对象列表

或使用投影选择,例如

SELECT e.name, e.salary FROM Employee e

它返回一个Object[] result其中 result[0] 是 e.name,result[1] 是 e.salary

有没有办法让 JPA 返回包含实体子集的 Map 例如是否有 JPQL 查询可以返回List<Map<String,Object>> result这样result.get(0).get("e.name") return e.name and result.get(0).get('e.salary') return e.salary

如果JPQL做不到,HQL能做吗?


JPA 提供有限数量的复合选择的返回类型 http://www.objectdb.com/java/jpa/query/jpql/select#SELECT_in_Criteria_Queries_:数组、元组和构造,而 Hibernate 提供了更多select 子句的返回类型 http://docs.jboss.org/hibernate/orm/4.1/manual/en-US/html/ch16.html#queryhql-select,其中包括地图。

SELECT NEW map(e.name, e.salary, e.department.name) FROM Employee e

此 HQL 查询返回一个Map从别名到选定值。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

从 JPQL 查询返回 JPA 实体的子集作为映射数组? 的相关文章

随机推荐