之前在弄一个经过公司框架改装后的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... 可以多次嵌套进去使用。