Hibernate出现 Users is not mapped
建了一个 struts2 +hibernate的Web项目,运行时发现报错 :
ERROR DefaultDispatcherErrorHandler Exception occurred during processing request: java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: Users is not mapped [ from Users u where u.uname=:name and u.pwd=:pass]
1.项目部分目录结构如下:
2.检查了一下映射,觉得没问题。
Users.hbm.xml:
<class name="entity.Users" table="users" catalog="user">
hibernate.cfg.xml:
<mapping resource="entity/Users.hbm.xml"/>
3.去网上查了下,得知hql语句中的表名应该是ORM映射的类名,而不是数据库中的表名。
String sql = " from users u where u.uname=:name and u.pwd=:pass";
原来是把hql语句中的Users写成了users,改正之后hql语句如下。
String sql = " from Users u where u.uname=:name and u.pwd=:pass";
4.但是语句改成Users之后,执行发现还是报这个错,于是乎去打印查询信息,发现Query接口的使用有问题,而且导包有警告。
5.查看自己的配置,自己使用的是hibernate5,而hibernate5中 org.hibernate.Query 被 org.hibernate.query.Query 替代了。
6.接着去官网下载了一个hibernate4.3的版本,把hibernate-core-5.2.6.Final.jar替换成hibernate-core-4.3.10.Final.jar后问题解决。
下载参考链接:https://blog.youkuaiyun.com/ss7xz/article/details/116334193
小结:不要使用hibernate5.0 使用4.2 或者4.3的版本