微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在 JPQL Hibernate 中使用 SUM(CASE WHEN ....)?

如何解决如何在 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 举报,一经查实,本站将立刻删除。