ITPub博客

首页 > 应用开发 > IT综合 > 报错java.lang.Long cannot be cast to java.lang.Integer解析

报错java.lang.Long cannot be cast to java.lang.Integer解析

原创 IT综合 作者:duwei880505 时间:2014-01-26 13:50:29 0 删除 编辑
用博客记录工作中出现的问题,给自己一个提醒,也给其他朋友一些借鉴。


报错: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); 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29445577/viewspace-1075561/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2014-01-16

  • 博文量
    7
  • 访问量
    29193