hibernate分组统计与聚合查询(原生sql和使用case when then else end的hql)【转】

之前在弄一个经过公司框架改装后的SSH项目,碰到了不少悲催的问题。。

项目是公司的内部信息化系统,十多年来经手千千万万人的OA办公系统。里面的代码已经面目全非。

 

因为hibernate里面是没有数据库函数东西的,所以类似decode这类函数和left join...on...(hibernate不支持on关键字),这些都有心无力了。

具体用法百度百科有。

解释如下:

DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )  

  Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。

 

不过该函数只能在Oracle里面用。。

 

回归正题,Oracle不能用数据库的函数,要么就使用纯SQL,session.createSQLQuery ,sqlQuery 那些来直接执行sql查询。

不过貌似还有一种方法就是通过 hibernate.query.substitutions 将Hibernate查询中的符号映射到SQL查询中的符号 (符号可能是函数名或常量名字)。这方法没用过。因为公司框架去掉了hibernate的包,封装成自己的了,好多方法没的没了,变形的变形了。

 

最后解决方案:

hibernate hql查询,使用case when then else end


select t.c1,t.c2,sum(case when t.status=0 then t.c3 else 0 end) group by t.c1,t.c2 .......


查询t表,对t表进行分组统计,判断 when 后面 then前面的表达式是否成立,成立返回 then 后面的,否则返回else后面的。end提示结束。。

when...then... 可以多次嵌套进去使用。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值