1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 关于java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to 实体类

关于java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to 实体类

时间:2020-10-07 19:49:03

相关推荐

关于java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to 实体类

由于业务逻辑的复杂,有些sql语句写法hql不支持,所以hibernate查询直接用了sql原生查询,由于数据结果根据四个表查询出来,所以无法使用方法.addEntity(XXXXXXX.class);把结果转对象,就这样以对象数组的形式传到了Action层,

然而Action层传到前台需要对数据进行封装一下(前台用的easyui,数据展示根据key名获取value值),所以进行转化(就在这浪费了我近两天的时间,气!),由于是对象数组的形式,网上搜索各种方法进行取值都无效,后来在impl层,把返回的格式返回为Pagenate<Object[]>形式,(原来是Pagenate<实体类>),在前台一顿遍历封装(取值方式采用的是下标取值,感谢/zb0567/article/details/7183043),然后成功

知识点:

hibernate 中createQuery与createSQLQuery两者区别是:

前者用的hql语句进行查询,后者可以用sql语句查询

前者以hibernate生成的Bean为对象装入list返回,后者则是以对象数组进行存储

所以使用createSQLQuery有时候也想以hibernate生成的Bean为对象装入list返回,就不是很方便

突然发现createSQLQuery有这样一个方法可以直接转换对象

Query query = session.createSQLQuery(sql).addEntity(XXXXXXX.class);

XXXXXXX 代表以hibernate生成的Bean的对象,也就是数据表映射出的Bean。但是这个bean必须有映射

/zb0567/article/details/7183043的原贴

java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to

List abc = zzteledao.GetUser("select aa,bbfrom cc where id="+ id);List temp=(List)abc.get(0);

这时会爆出如题的错误,是因为select出来的是一个object,两个项目,debug出来的像list一样,l但是转换还是出错

后来改成如下

if (abc != null) {Object[] le = (Object[]) abc.get(0);aa= le[0].toString();bb= le[1].toString();}

即可解决

另外一种就是Lei{aa,bb}这样的类,用类来替代

Lei temp=(Lei)abc.get(0)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。