报错:java.lang.Long cannot be cast to java.lang.Integer 
  Long 无法转化成Integer类型. 
  这个异常 经常出现在hinbernate分页查询的时候. 

原因: 

        这里在Hibernate2.0之前版本list.get(0)返回的是Integer类型. 
        但是在Hibernate3.0以后版本list.get(0)返回的是Long类型. 
        所以在这里不可以由Long型强转成Integer类型. 
   
Integer属于不可更改类型,而且Long和Integer没有任何继承关系,当然不能这样转换。    

  例如: 
           注: super.pageQuery(hql,null,null,null);调用了一个父类的一个封装方法.查询时候使用 
           List list = this.getHibernateTemplate().executeFind(new HibernateCallback(){}); 

Java代码  收藏代码

  1. /** 

  2.  * 查询所有用户记录总数 

  3.  */  

  4.  public Integer getUsersCount() {  

  5. String hql = "select count(*) from Users";  

  6. List list = super.pageQuery(hql, nullnullnull);  

  7. return (Integer) list.get(0);  

  8.  }  


              

解决办法: 
1.网上的方法 觉得不太好 

Java代码  收藏代码

  1. public Integer getUsersCount() {  

  2.   String hql = "select count(*) from Users";  

  3.   List list = super.pageQuery(hql, nullnullnull);  

  4.   Number num = (Number) list.get(0);  

  5.   return num.intValue();  

  6.   }  

  7.          注:java.lang.Number是Integer,Long的父类.  


2.我的方法 

Java代码  收藏代码

  1. Object obj =session.createQuery(getcount).list().get(0);  

  2. long count= (Long)obj;  

  3. Page page = new Page(pageNum,(int)count,pageSize);