<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    【Hibernate總結系列】常見異常總結(不斷補充)

     

           本文總結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類中的屬性的gettersetter方法不一致。

    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的取值可以為incrementidentitysequencehilonative……等,更多的可參考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)因為該方法是從hibernatesession中去重新取object,如果session中沒有這個對象,則會報錯所以當你使用saveOrUpdate(object)之前還需要判斷一下。

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

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

           當出現SQL Grammer Exception,Could not execute JDBC batch update異常時,一般是由如下問題引起:

    1SQL語句中存在語法錯誤或是傳入的數據有誤;

    2)數據庫的配置不合法,或者說是配置有誤。較容易出現的有數據表的映射文件(,hbm.xml文件)配置有誤;Hibernate.cfg.xml文件配置有誤;

    3 當前的數據庫用戶權限不足,不能操作數據庫。以是以Oracle 數據庫為例,這種情況下在錯誤提示中會顯示java.sql.BatchUpdateException: ORA-01031: insufficient privileges這樣的信息。

           針對上面的各種原因,開發人員可以找出對應的解決方案。

    http://m.tkk7.com/amigoxie/category/19976.html

    posted on 2008-11-15 21:52 smallfa 閱讀(273) 評論(0)  編輯  收藏 所屬分類: hibernate/ibatis

    <2008年11月>
    2627282930311
    2345678
    9101112131415
    16171819202122
    23242526272829
    30123456

    導航

    統計

    公告

    smallfa
    博客園
    C++博客
    博客生活
    Blogjava
    足球博客
    微博
    Redsaga

    常用鏈接

    留言簿(2)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊

    Ajax

    Blogs

    DB

    java

    Open source

    ORM

    Tools/Help

    vedio Tech

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 97公开免费视频| 亚洲w码欧洲s码免费| 在线日韩av永久免费观看| 亚洲精品国产肉丝袜久久| 日韩精品无码专区免费播放| 国产V亚洲V天堂A无码| 午夜视频免费在线观看| 色婷婷六月亚洲婷婷丁香| 曰批全过程免费视频播放网站| 亚洲第一网站免费视频| 国产精品永久免费10000| 自拍偷区亚洲国内自拍| 国产成人涩涩涩视频在线观看免费| 国产精品亚洲天堂| 国产亚洲av人片在线观看| 免费无码黄网站在线看| 亚洲国产精品美女| 永久免费看mv网站入口| 人妻免费久久久久久久了| 精品亚洲一区二区| 97在线观免费视频观看 | 免费中文字幕一级毛片| xxxx日本在线播放免费不卡| 久久九九亚洲精品| 成人A级毛片免费观看AV网站| 激情婷婷成人亚洲综合| 狠狠综合久久综合88亚洲| 91成人免费观看| 亚洲精品乱码久久久久久V| 亚洲国产V高清在线观看| 88xx成人永久免费观看| 亚洲狠狠色丁香婷婷综合| 亚洲国产一成人久久精品| 在线视频精品免费| 九九九国产精品成人免费视频| 亚洲成A人片在线观看无码不卡 | 国产亚洲精品免费| 东方aⅴ免费观看久久av| 亚洲香蕉久久一区二区| 亚洲色一色噜一噜噜噜| 2020久久精品国产免费|