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方法,感谢一下。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值