ssh 报错hibernate java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to XXX
ssh 报错hibernate java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to XXX
这个应该说是hibernate报错:hibernate java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to XXX。
这个错误原因是sql查询的list返回值为object类型,而你的需求是XXX类型,类型不匹配所导致的。
解决方法
网上搜索出来的方法一般是把createQuery改为createSQLQuery,并且添加.addEntity(XXX.class);//XXX为你需要的实体类
1
|
Query query=session.createQuery(selectAllBookSql); |
改为
1
|
Query query=session.createSQLQuery(selectAllBookSql).addEntity(EntityBook. class ); |
但是在idea中会有一道划线提醒你这个createSQLQuery方法不推荐你使用,所以最好还是改为下面的方法:createNativeQuery
改为
1
|
Query query=session.createNativeQuery(selectAllBookSql).addEntity(EntityBook. class ); |
差点忘记了,由于你的查询方法不是hql,而是sql了,所以你的查询语句应该由“from …………”变为了“select …… from ……”;