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

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

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

    posts - 73,  comments - 55,  trackbacks - 0
    首先引用另一個blog的說法:

    1.cascade="..."?

    cascade屬性并不是多對多關系一定要用的,有了它只是讓我們在插入或刪除對像時更方便一些,只要在cascade的源頭上插入或是刪除,所有cascade的關系就會被自己動的插入或是刪除。便是為了能正確的cascade,unsaved- value是個很重要的屬性。

    Hibernate通過這個屬性來判斷一個對象應該save還是update,如果這個對象的id是 unsaved-value的話,那說明這個對象不是persistence object要save(insert);如果id是非unsaved-value的話,那說明這個對象是persistence object(數據庫中已存在),只要update就行了。saveOrUpdate方法用的也是這個機制。

    2.inverse="ture"?

    inverse 屬性默認是false的,就是說關系的兩端都來維護關系。這個意思就是說,如有一個Student, Teacher和TeacherStudent表,Student和Teacher是多對多對多關系,這個關系由TeacherStudent這個表來表現。那么什么時候插入或刪除TeacherStudent表中的記錄來維護關系呢?在用hibernate時,我們不會顯示的對 TeacherStudent表做操作。

    對TeacherStudent的操作是hibernate幫我們做的。hibernate就是看 hbm文件中指定的是"誰"維護關系,那個在插入或刪除"誰"時,就會處發對關系表的操作。前提是"誰"這個對象已經知道這個關系了,就是說關系另一頭的對象已經set或是add到"誰"這個對象里來了。前面說過inverse默認是false,就是關系的兩端都維護關系,對其中任一個操作都會處發對表系表的操作。當在關系的一頭,如Student中的bag或set中用了inverse="true"時,那就代表關系是由另一關維護的(Teacher)。就是說當這插入Student時,不會操作TeacherStudent表,即使Student已經知道了關系。只有當 Teacher插入或刪除時才會處發對關系表的操作。

    所以,當關系的兩頭都用inverse="true"是不對的,就會導致任何操作都不處發對關系表的操作。當兩端都是inverse="false"或是default值是,在代碼對關系顯示的維護也是不對的,會導致在關系表中插入兩次關系。在一對多關系中inverse就更有意義了。在多對多中,在哪端inverse="true"效果差不多(在效率上)。但是在一對多中,如果要一方維護關系,就會使在插入或是刪除"一"方時去update"多"方的每一個與這個"一"的對象有關系的對象。

    而如果讓"多"方面維護關系時就不會有update操作,因為關系就是在多方的對象中的,直指插入或是刪除多方對象就行了。當然這時也要遍歷"多"方的每一個對象顯示的操作修關系的變化體現到DB中。不管怎樣說,還是讓"多"方維護關系更直觀一些。

    3.cascade和inverse有什么區別?

    可以這樣理解,cascade定義的是關系兩端對象到對象的級聯關系;而inverse定義的是關系和對象的級聯關系。在一對多映射中,一的一方要設<set (inverse="false") casecade="save-update" />,多的一方要設<many-to-one inverse=true (casecade="none") />
    Wenic的blog:Wenic的blog:http://www.matrix.org.cn/blog/wenic705
    ------------------------------------

    這個是我做的用例。測試cascade和inverse.分析結果以及具體hibernate sql都在,比較容易看明白。
    希望不是很明白的看看,加深印象。
    小弟學識淺薄,如果有不對的地方,請指出來,謝謝!~
    測試環境:Eclispe,用斷點測試。
    ??????????數據庫是SQLServer2000.

    Area.hbm.xml

    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"; >
    <hibernate-mapping>
    <class name="net.villion.model.test.Area" table="r_area">
    <id column="ID" type="long" name = "id" length="10" unsaved-value="null">
    <generator class = "native"/>
    </id>
    <property column="name" name="name" type="string"/>
    <many-to-one name="state" class="net.villion.model.test.State" cascade="all">
    <column name="stateid" index="index_area_state"/>
    </many-to-one>
    </class>
    </hibernate-mapping>






    State.hbm.xml
    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"; >
    <hibernate-mapping>
    <class name="net.villion.model.test.State" table="r_state">
    <id column="ID" type="long" name = "id" length="10" unsaved-value="null">
    <generator class = "native"/>
    </id>
    <property column="name" name="name" type="string"/>
    <set name="areas" lazy="true" cascade="all" inverse="false">
    <key column="stateid"/>
    <one-to-many class="net.villion.model.test.Area"/>
    </set>

    </class>
    </hibernate-mapping>



    我們主要看inverse,cascade級聯的設置。
    當State.hbm.xml inverse = "false" cascade = "all"
    //添加
    //code??
    StateDAO sdao =(StateDAO) ctx.getBean("stateDAO");
    AreaDAO adao = (AreaDAO)ctx.getBean("areaDAO");????????????
    Area a3 = new Area();
    a3.setName("NewYork");
    Area a4 = new Area();
    a4.setName("Frolida");
    State s2 = new State();
    s2.setName("America");??
    Set set = new HashSet();
    set.add(a3);
    set.add(a4);
    s2.setAreas(set);
    sdao.saveObject(s2);
    ??????
    //sql:
    Hibernate: insert into r_state (name) values (?)
    Hibernate: insert into r_area (name, stateid) values (?, ?)
    Hibernate: insert into r_area (name, stateid) values (?, ?)
    Hibernate: update r_area set stateid=? where ID=?
    Hibernate: update r_area set stateid=? where ID=?


    //當State.hbm.xml inverse = "false" cascade = "none"(注意我們操作的是State)

    //sql: insert into r_state (name) values (?)

    Hibernate: update r_area set stateid=? where ID=?
    org.springframework.dao.InvalidDataAccessApiUsageException: object references an unsaved transient instance

    這時候更新area的時候由于area,并未級聯插入所以找不到報錯。所以這樣設置還是會更新Area的stateid
    接著上面的說,我們要看當設置改變時的sql變化。
    上面就說明了cascade="all" 時候能級聯插入,而none的時候只是維持兩者之間的關系(inverse="false")。
    上面兩種情況的刪除又不一樣了,但是一個道理
    cascade="all"時,兩個表數據都級聯刪除了。

    而cascade="none"時
    Hibernate: update r_area set stateid=null where stateid=?
    Hibernate: delete from r_state where ID=?說明它只是維持關系。

    而當上面的inverse ="true"時 cascade="none"時
    sql: insert into r_state (name) values (?)
    只插入一條State,不會插入Area表了。
    刪除時
    Hibernate: delete from r_state where ID=?
    org.springframework.dao.DataIntegrityViolationException: (Hibernate operation): data integrity violated by SQL ''; nested exception is com.jnetdirect.jsql.u: DELETE 語句與 COLUMN REFERENCE 約束 'FKC7F1003A8EEBF16C' 沖突。該沖突發生于數據庫 'hd',表 'r_area', column 'stateid'。
    com.jnetdirect.jsql.u: DELETE 語句與 COLUMN REFERENCE 約束 'FKC7F1003A8EEBF16C' 沖突
    由于沒有維護數據庫關系,引起外鍵沖突報錯。


    inverse ="true"時 cascade="all"時
    sql:
    Hibernate: insert into r_state (name) values (?)
    Hibernate: insert into r_area (name, stateid) values (?, ?)
    Hibernate: insert into r_area (name, stateid) values (?, ?)
    全部級聯插入,但r_area表中stateid是null。
    刪除時。
    Hibernate: delete from r_area where ID=?
    Hibernate: delete from r_area where ID=?
    Hibernate: delete from r_state where ID=?
    級聯刪除。


    所以總結一下 ,cascade 是級聯的程度,而inverse="false|ture" 是指是否維持兩個實體的關系。(兩個表的外鍵)。

    水平有限,請各位看客口下留情。
    如果耽誤了你的寶貴,我在這里道歉了。 :(
    posted on 2006-06-15 15:00 保爾任 閱讀(671) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(4)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 看一级毛片免费观看视频| 亚洲成av人片天堂网老年人| 久久国产亚洲观看| 国产成年无码久久久免费| 亚洲午夜久久久影院伊人| 狠狠躁狠狠爱免费视频无码| 中文字幕亚洲专区| 你是我的城池营垒免费观看完整版| 亚洲精品无码久久久久去q| 皇色在线免费视频| 久久丫精品国产亚洲av不卡| 毛片免费全部播放无码| 亚洲综合成人婷婷五月网址| 免费观看毛片视频| yellow免费网站| 亚洲人成在线影院| 成人五级毛片免费播放| 人妻无码中文字幕免费视频蜜桃| 中文字幕精品亚洲无线码一区| 国产免费阿v精品视频网址| 亚洲欧洲日产国码www| 性感美女视频在线观看免费精品 | 亚洲激情视频网站| 成人免费在线观看网站| 成人a毛片视频免费看| 亚洲AV无码乱码国产麻豆穿越| 国产在线观看片a免费观看| 怡红院亚洲红怡院在线观看| 国产成人亚洲精品狼色在线| 久久久久久精品免费免费自慰| 亚洲av成人片在线观看| 亚洲AV永久无码精品| 暖暖在线日本免费中文| 13小箩利洗澡无码视频网站免费| 亚洲一区中文字幕在线电影网| 亚洲国产精品嫩草影院久久| **真实毛片免费观看| 成人特级毛片69免费观看| 亚洲成a人片毛片在线| 18禁免费无码无遮挡不卡网站| 亚洲heyzo专区无码综合|