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为你需要的实体类
Query query=session.createQuery(selectAllBookSql);
改为
Query query=session.createSQLQuery(selectAllBookSql).addEntity(EntityBook.class);
但是在idea中会有一道划线提醒你这个createSQLQuery方法不推荐你使用,所以最好还是改为下面的方法:createNativeQuery
改为
Query query=session.createNativeQuery(selectAllBookSql).addEntity(EntityBook.class);
差点忘记了,由于你的查询方法不是hql,而是sql了,所以你的查询语句应该由“from …………”变为了“select …… from ……”;