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 ……”;

posted @ 2022-08-22 22:01  SHINEJACKXN  阅读(166)  评论(0编辑  收藏  举报