Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员
查看: 5|回复: 0

Hibernate 菜鸟教程 异常 集锦

[复制链接]
  • TA的每日心情
    奋斗
    昨天 19:16
  • 签到天数: 66 天

    [LV.6]常住居民II

    1348

    主题

    1348

    帖子

    3万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    32858
    发表于 2021-6-10 23:21:42 | 显示全部楼层 |阅读模式

    异常1.Error parsing JNDI name [foo]

    异常信息摘要:

    org.hibernate.engine.jndi.JndiException: Error parsing JNDI name [foo] at org.hibernate.engine.jndi.internal.JndiServiceImpl.parseName(JndiServiceImpl.java:141)
    • 1
    • 2

    异常信息说明:不能解析连接池foo

    拷贝官方配置文件hibernate.cfg.xml的里面<session-factory name=”foo”>默认包含此foo属性配置,此异常不过是不影响运行的结果

    解决思路:删除name=”foot”即可


    异常2.org.hibernate.boot.registry.classloading.spi.ClassLoadingException: Unable to load class [com.mysql.jdbc.Driver]

    异常信息摘要:

    org.hibernate.boot.registry.classloading.spi.ClassLoadingException: Unable to load class [com.mysql.jdbc.Driver] at org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.classForName(ClassLoaderServiceImpl.java:243) at org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.loadDriverIfPossible(DriverManagerConnectionProviderImpl.java:200)
    • 1
    • 2
    • 3

    异常信息说明:不能加载mysql驱动 
    解决思路:拷贝mysql驱动至classpath或者修改maven的pom.xml

    <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.40</version> </dependency>
    • 1
    • 2
    • 3
    • 4
    • 5

    异常3.密码错误

    异常信息摘要:

    org.hibernate.exception.JDBCConnectionException: Error calling Driver#connect Caused by: java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)
    • 1
    • 2

    异常信息说明:不能获取连接

    解决思路:修改mysql的密码至正确

    密码写错或者connection.pasword少写一个s字母
    <property name="connection.pasword">12345</property>
    • 1
    • 2

    异常4.连接数据库url错误

    异常信息摘要:

    java.lang.UnsupportedOperationException: The application must supply JDBC connections
    <property name="connection.urls">jdbc:mysql:///hibernate</property> org.hibernate.HibernateException: Unable to make JDBC Connection [jdbc:mysql6:///hibernate] <property name="connection.url">jdbc:mysql:///hibernate</property>
    • 1
    • 2
    • 3
    • 4

    异常信息说明:url地址或者key写错

    解决思路:修改url地址或者key

    <property name="connection.url">jdbc:mysql:///hibernate</property>
    • 1

    异常5.未知实体类

    异常信息摘要:

    org.hibernate.MappingException: Unknown entity: com.jege.hibernate.single.table.User at org.hibernate.internal.SessionFactoryImpl.getEntityPersister(SessionFactoryImpl.java:1096) at org.hibernate.internal.SessionImpl.getEntityPersister(SessionImpl.java:1443)
    • 1
    • 2
    • 3

    异常信息说明:映射异常,hibernate配置文件没有加载映射文件

    解决思路:在配置文件中通过mapping元素将映射文件加载进来

    <mapping resource="com/jege/hibernate/single/table/User.hbm.xml" />
    • 1

    异常6.全类名写错

    异常信息摘要:

    org.hibernate.InvalidMappingException: Could not parse mapping document from resource com/jege/hibernate/single/table/User.hbm.xml Caused by: org.hibernate.MappingException: class com.jege.hibernate.single.table.User.User not found while looking for property: id Caused by: java.lang.ClassNotFoundException: com.jege.hibernate.single.table.User.User <hibernate-mapping package="com.jege.hibernate.single.table.User"> <class name="User" table="t_user">
    • 1
    • 2
    • 3
    • 4
    • 5

    异常信息说明:映射文件全类名不正确

    解决思路:修改全类名

    属性package只写包路径,不要将类名也写进去 <hibernate-mapping package="com.jege.hibernate.single.table"> <class name="User" table="t_user">
    • 1
    • 2
    • 3

    异常7.属性名写错

    异常信息摘要:

    org.hibernate.InvalidMappingException: Could not parse mapping document from resource com/jege/hibernate/single/table/User.hbm.xml Caused by: org.hibernate.PropertyNotFoundException: field [userUame] not found on com.jege.hibernate.single.table.User <property name="userUame" column="name" />
    • 1
    • 2
    • 3
    • 4

    异常信息说明:映射文件属性名不正确

    解决思路:修改属性名

    <property name="username" column="name" />
    • 1

    异常8.对象不存在

    异常信息摘要:

    org.hibernate.ObjectNotFoundException: No row with the given identifier exists: [com.jege.hibernate.single.table.User#5] User user = (User)session.load(User.class, 5L); System.out.println(user.getPassword());
    • 1
    • 2
    • 3
    • 4

    异常信息说明:load方法没有找到对应的主键的实体

    解决思路:使用get方法替换load,判断返回值是否null

    User user = (User) session.get(User.class, 5L); if (user != null) { System.out.println(user.getPassword()); }

    引用原文:https://blog.csdn.net/je_ge/article/details/53875649

     

    写博客是为了记住自己容易忘记的东西,另外也是对自己工作的总结,文章可以转载,无需版权。希望尽自己的努力,做到更好,大家一起努力进步!

    如果有什么问题,欢迎大家一起探讨,代码如有问题,欢迎各位大神指正!

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2021-6-22 22:05 , Processed in 0.056031 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2020, Tencent Cloud.

    快速回复 返回顶部 返回列表