Hibernate一句话分页代码


我想在DAO实现类里使用以下这句代码应该是最简单的通用分页代码了:
findByProperty(propertyName,value).subList(firstRow, firstRow+maxRow);
说明:findByProperty可以由hibernate自己生成;
参数:propertyName:属性名称;
      value:属性值(可以是任意类型:String,Object,Integer....);
     firstRow:页码(可以从http请求获取);
      maxRow:每页记录数;

TroubleShooting:
用这个方法的时候要把XXX.hbm.xml的many-to-one 的lazy属性设置为false,
例如我的:
<many-to-one name="channel" class="com.cabin.vo.Channel" lazy="false" column="chanel_id" />
我发现这个方法比网上流行的下面这个方法省很多事。
下面这个方法常遇到的错误是:用VO的某个属性查询时如果次属性是object对象会产生异常; org.springframework.orm.hibernate3.HibernateQueryException: unexpected char: '@'。。。。。这就是我先前采用的代码,结果当查询的属性事另外一个vo时出现异常。
public List findPage( final  String sql, final   int  firstRow, final   int  maxRow){
return   this .getHibernateTemplate().executeFind( new  HibernateCallback(){
            public  Object doInHibernate(Session session)  throws  SQLException,
                   HibernateException {
           
              Query q  =  session.createQuery(sql);
             
              q.setFirstResult(firstRow);
              q.setMaxResults(maxRow);
               return  q.list();
              }
       }); 
}


这是我最近无意发现的,也许您早就知道了,呵呵。。。。

你可能感兴趣的:(DAO,sql,Hibernate,xml,orm)