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

你可能感兴趣的:(oracle,sql,工作,Blog)