java.lang.Long cannot be cast to java.lang.String

来源:百度知道 编辑:UC知道 时间:2024/06/06 02:28:49
public Collection getOptions(String key)throws Exception
{
StringBuilder Hql=new StringBuilder()
.append("select new list(d.dname as dname,d.did as did)")
.append(" from Department d ")
.append(" where d.dcode=?")
;
List<List> items=this.getHibernateTemplate().find(Hql.toString(), new Object[]{key});
int size=items.size();
System.out.println("items is ========"+items);
Collection coll=new ArrayList();
for(List<String> item:items)
{ System.out.println("items is ========"+items.get(0));
coll.add(new LabelValueBean(item.get(0),item.get(1)));
}
return coll;
}

coll.add(new LabelValueBean(item.get(0),item.get(1)));
这行总报错。。。。我很不解。。。。谁能详细说说 再帮我改改~~~会加分哦
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessor

一、原因:
1)在Hibernate2.0之前版本list.get(0)返回的是Integer类型.
2)在Hibernate3.0以后版本list.get(0)返回的是Long类型,不可以由Long型强转成Integer类型.
3)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);
Number num = (Number) list.get(0);
return num.intValue();
}
注:java.lang.Number是Integer,Long的父类.

类LabelValueBean里的变量是String类型的,item.get(0)是Long型的,需要一下类型转换吧:
coll.add(new LabelValueBean