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

xiaoxiao2021-02-28  106

参考: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,也报了同样的问题。

转载请注明原文地址: https://www.6miu.com/read-73059.html

最新回复(0)