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

参考:http://blog.csdn.net/kingo0/article/details/21792857


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

/** 
 * 查询所有用户记录总数 
 */  
 public Integer getUsersCount() {  
String hql = "select count(*) from Users";  
List list = super.pageQuery(hql, null, null, null);  
return (Integer) list.get(0);  
 }  

/** 
 * 查询所有用户记录总数 
 */  
 public Integer getUsersCount() {  
String hql = "select count(*) from Users";  
List list = super.pageQuery(hql, null, null, null);  
return (Integer) list.get(0);  
 }  
解决办法: 
1.网上的方法 觉得不太好 
public Integer getUsersCount() {  
  String hql = "select count(*) from Users";  
  List list = super.pageQuery(hql, null, null, null);  
  Number num = (Number) list.get(0);  
  return num.intValue();  
  }  
         注:java.lang.Number是Integer,Long的父类.  
[java] view plain copy
public Integer getUsersCount() {  
  String hql = "select count(*) from Users";  
  List list = super.pageQuery(hql, null, null, null);  
  Number num = (Number) list.get(0);  
  return num.intValue();  
  }  
         注:java.lang.Number是Integer,Long的父类. 
2.我的方法 

Object obj =session.createQuery(getcount).list().get(0);  
long count= (Long)obj;  
Page page = new Page(pageNum,(int)count,pageSize);  

==============【也就是:先转为long,再强转为int。】

我在Servlet+Jsp网上商城,mysql商品分页查询时也遇到这个问题。

查询select count(*) from product。查询总记录数时,返回值Object类型,我直接强转int,也报了同样的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值