• Hibernate中常见的异常处理


    本文引自:http://www.blogjava.net/sy1214520/archive/2008/10/21/235667.html
    本文总结Hibernate中常见的异常。

    1. net.sf.hibernate.MappingException

           当出现net.sf.hibernate.MappingException: Error reading resource:…异常时一般是因为映射文件出现错误。

           当出现net.sf.hibernate.MappingException: Resource: … not found是因为XML配置文件没找到所致,有可能是放置目录不正确,或者没将其加入hibernate.cfg.xml中。

    2. net.sf.hibernate.PropertyNotFoundException

           当出现net.sf.hibernate.PropertyNotFoundException: Could not find a setter for property name in class …时,原因一般是因为XML映射文件中的属性与对应的Java类中的属性的getter或setter方法不一致。

    3. org.hibernate.id.IdentifierGenerationException

           当出现org.hibernate.id.IdentifierGenerationException: ids for this class must be manually assigned before calling save():异常时,一般是因为<id>元素配置不正确,<id>元素缺少其子元素<generator></generator>的配置引起。

           解决方案:<id>元素映射了相应数据库表的主键字段,对其子元素<generator class="">,其中class的取值可以为increment、identity、sequence、hilo、native……等,更多的可参考hibernate参考文档,一般取其值为native 。具体可参考2.2.2.1小节。

    4. a different object with the same identifier value was already associated with the session

           当出现a different object with the same identifier value was already associated with the session时,一般是因为在hibernate中同一个session里面有了两个相同标识但是是不同实体。

           有如下几种解决方案:

    (1)使用session.clean(),如果在clean操作后面又进行了saveOrUpdate(object)等改变数据状态的操作,有可能会报出"Found two representations of same collection"异常。

    (2)使用session.refresh(object),当object不是数据库中已有数据的对象的时候,不能使用session.refresh(object)因为该方法是从hibernate的session中去重新取object,如果session中没有这个对象,则会报错所以当你使用saveOrUpdate(object)之前还需要判断一下。

    (3)session.merge(object),Hibernate里面自带的方法,推荐使用。

    5. SQL Grammer Exception,Could not execute JDBC batch update

           当出现SQL Grammer Exception,Could not execute JDBC batch update异常时,一般是由如下问题引起:

    (1)SQL语句中存在语法错误或是传入的数据有误;

    (2)数据库的配置不合法,或者说是配置有误。较容易出现的有数据表的映射文件(,hbm.xml文件)配置有误;Hibernate.cfg.xml文件配置有误;

    (3) 当前的数据库用户权限不足,不能操作数据库。以是以Oracle 数据库为例,这种情况下在错误提示中会显示java.sql.BatchUpdateException: ORA-01031: insufficient privileges这样的信息。

           针对上面的各种原因,开发人员可以找出对应的解决方案。

  • 相关阅读:
    mysql中delimiter
    error: unpacking of archive failed on file /usr/sbin/zabbix_agent;592e5bc3: cpio: open
    CefSharp中文帮助文档
    ASP.NET Aries 开发框架
    简洁的富文本编辑器
    asp.net core 获取appsettings.json里的配置
    在asp.net core中使用NLog
    临时禁用Resharper
    visual studio 无添加视图 选项
    visual studio(vs)初始化
  • 原文地址:https://www.cnblogs.com/xtreme/p/3877425.html
Copyright © 2020-2023  润新知