本文详解如何在 spring data jpa 中正确编写 jpql 构造函数查询(constructor expression),重点解决因误用 nativequery、实体名大小写错误及属性名不匹配导致的常见异常。
在 Spring Data JPA 中,使用 SELECT new 语法调用 DTO 构造函数是实现类型安全投影(Type-Safe Projection)的常用方式。但该功能仅适用于 JPQL 查询,不支持原生 SQL(native query)。你遇到的 InvalidDataAccessResourceUsageException 异常,根本原因在于将 JPQL 语法(如 new com.xxx.dto.Class(...))与 nativeQuery = true 错误混用——JDBC 驱动无法识别 new 关键字,从而抛出 SQL 解析失败。
✅ 正确做法如下:
修正后的完整代码如下:
@Query("SELECT new com.eminyilmazz.smoketracker.dto.ActivityBasedQuant
ity(s.activity, SUM(s.quantity)) " +
"FROM Smoke s " +
"WHERE s.smokedDate BETWEEN :beginDate AND :endDate " +
"GROUP BY s.activity")
List getTotalQuantityGroupedByActivityWithMinuteInterval(
@Param("beginDate") LocalDateTime beginDate,
@Param("endDate") LocalDateTime endDate);⚠️ 注意事项:
总结:JPQL 构造函数查询是高效、类型安全的轻量级投影方案,但必须严格遵循 JPQL 语法规则——以实体为中心、禁用 nativeQuery、注意命名大小写与驼峰映射。一次配置失误(如 nativeQuery = true)即可导致整个查询失效,排查时请优先核对这三项基础要素。