`
zhangjunji111
  • 浏览: 46477 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

hql写的一个取最大值的语句

阅读更多

  前段时间忙与换工作,好久没有写blog了。以前公司只用oracle数据库,而且开发用jdbcTemplate,什么查询了之类的直接用sql语句就搞定了,可现在改用hebernate,同时公司说要考虑各数据库兼容性的问题,所以许多oracle特有的特性便不能使用,这不,现在就遇到了一个问题需要解决了,需要从一个列表里面找到某一个字段的最大序号,可这个列是字符串类型,格式为‘省份’+'部门'+顺序号,现在需要根据省份以及部门找到最大的序号,我以前用sql语句很容易就可以解决该问题了.解决办法:
 先取该列中的序号,然后将其转化为整型,再取最大值就可以,sql语句如下:

 select max(to_number(substr(列名,前缀长度))) maxnum from 表名

 
  现在要用hql解决,而我以前也不了解hql,还要有internet,从网上找了找资料,还真找到了,hql也提供获取子串的函数,SUBSTRING(s,offset,length)得到hql语句:

selelct  max(SUBSTRING(对象.属性名,前缀长度)) from 对象,

 
  测试了一下,发现结果正确,呵呵,有点沾沾自喜了,可是运行了一段时间,却发现序号超过了10的时候,出现问题了,每次取到最大值都是10,执行sql语句发现没有将子字串转化为整形,导致排序是按照字符串类型排序的,再上网查找hql的类型转化,找到了类型转化函数,CAST(t as TYPE)。
  修改hql语句为:

selelct  max( CAST(SUBSTRING(对象.属性名,前缀长度),integer)) from 对象

 

 

执行sql语句,问题搞定。

这里参考了javaeye中http://wangtong40.iteye.com/blog/355624的文章中的hql方法,感谢一下。

分享到:
评论
4 楼 zhangjunji111 2010-07-12  
iq527 写道
如果用namedquery可以吗?

namedquery我没有尝试过,不过你可以试一下,如果可以,也可以贴出来。
3 楼 zhangjunji111 2010-07-12  
lxtkong-029 写道
不错,挺好的。如果数据量有3000万以上的话,不知道效率如何

如果数据量超过3000万,我估计会死,以前工作时候,数据量超过1000万时候,取总量都会等好长时间的。
2 楼 iq527 2010-07-12  
如果用namedquery可以吗?
1 楼 lxtkong-029 2010-07-12  
不错,挺好的。如果数据量有3000万以上的话,不知道效率如何

相关推荐

Global site tag (gtag.js) - Google Analytics