HQL语句中数据类型转换

Posted 古兰精

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HQL语句中数据类型转换相关的知识,希望对你有一定的参考价值。

  我们需要从数据库中取出序号最大的记录,想到的方法就是使用order by子句进行排序(desc倒序),然后取出第一个对象,可是当初设计数据库时(我们是在原来的数据库的基础上开发新系统),竟然将序号字段的类型设成了varchar2,真是让人郁闷,这样的话,如果排序的话,就是对字符串排序,12是比2小的数,那么就需要转换一下类型。

     以下写法调整中是错误的,不能执行,报空指针错误:select cast(t.a as Integer) from table_1 t

    我也使用了这段代码,同样报空指针异常,不知道怎么回事,我的脑袋里突然冒出一个想法,将Integer的I变为小写,代码如下:

public List findByPlanId(String id){   
     return getHibernateTemplate().find("from edu.bjtu.port.domain.DetailOfPlanForDayAndNight p where p.id.planId=? order by cast(p.id.detailId as integer) desc",id);   
}  

  这样就成功了。

       这段代码的另一个让我注意的地方是,当使用复合主键时,创建一个主键类,然后想要使用其中的一个主键进行查询,必须要这样写  p(实体类).id(主键类).planId(其中的某个主键),下面是对应的配置文件:

  XML代码:

<class name="edu.bjtu.port.domain.DetailOfPlanForDayAndNight" table="PD1_DNPLAN_DTL" schema="SOMIS">  
           <composite-id name="id" class="edu.bjtu.port.domain.DetailOfPlanForDayAndNightId">  
               <key-property name="planId" type="java.lang.String">  
                   <column name="DNPLANID" length="8" />  
               </key-property>  
               <key-property name="detailId" type="java.lang.String">  
                   <column name="NO" length="2" />  
               </key-property>  
           </composite-id>  

  其实这个问题在Hibernate开发手册中有写,只是我还没看到,之所以想到这样写,完全是突然灵光乍现。不过看来手册还要继续好好研究啊~

实例:HQL语句中

public GenuineManagementStatic queryNewVersion(Integer softId) {
        List<GenuineManagementStatic> list = getSession().createQuery(" from " + this.clazz.getName() + " this WHERE this.softId=:softId  order by cast(version as integer) desc LIMIT 0,1")
                .setParameter("softId", softId)
                .list();
        if (list.size() > 0) {
            return list.get(0);
        }
        return null;
    }

 

以上是关于HQL语句中数据类型转换的主要内容,如果未能解决你的问题,请参考以下文章

hql语句cast用法详解下

hql语句cast用法的详解?

JAVA中用Hql语句从数据库中读取数据,字符拼接问题

Oracle数据库的HQL语句操作语法

hibernate hql查询 与Criteria 查询语句区别和效率

HQL语句 distinct 的用法