如何解决如何在 JPQL Hibernate 中使用 SUM(CASE WHEN ....)?
Query qQuery = entityManager.createquery("select " +
" sum((case when mt.prop1 = true then 1 else 0 end))," +
" sum((case when mt.prop2 = true then 1 else 0 end))," +
" sum((case when mt.prop3 = false then 1 else 0 end))," +
" sum((case when mt.prop3 = true then 1 else 0 end)) " +
"from MyTable mt " +
"where mt.id = :myId ");
但是,当我将 case 语句放入聚合中时,这会在查询中引发语法错误。
我可以让 SUM 单独工作正常,并且 case 语句单独工作正常。我想知道 JPQL 是否可以支持聚合中的案例,或者我是否被迫使用本机查询。
解决方法
呃……虚惊一场。 IntelliJ 只是愚蠢。我刚刚运行了查询,它很好。 IntelliJ 仍然显示错误,但它可以工作。
对于遇到此问题的任何人......即使在 IntelliJ 或其他 IDE 出现错误提示的情况下,也请在得出结论之前运行它。有时 IDE 只是错误的。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。