一杯清茶

          統計

          留言簿

          Oracle SQL/PLSQL

          PowerDesigner教程系列

          Struts2.0

          web開發

          三人行

          從事RCP開發的同行

          工作流和權限設置

          閱讀排行榜

          評論排行榜

          hibernate中inverse的用法

          轉自:http://blog.csdn.net/leader_lx/archive/2008/08/06/2774137.aspx

          一、Inverse是hibernate雙向關系中的基本概念。inverse的真正作用就是指定由哪一方來維護之間的關聯關系。當一方中指定了“inverse=false”(默認),那么那一方就有責任負責之間的關聯關系,說白了就是hibernate如何生成Sql來維護關聯的記錄! 

           

                  Hibernate僅僅按照主控方對象的狀態的變化來同步更新數據庫。按照原來的映射文件,people.getAddresses().add(address),即主控方對象的狀態發生了改變,因此數據庫會跟著對象狀態的變化來同步更新數據庫;而address.setPeople(people),即被控方對象的狀態發生了改變,它是不能觸發對象和數據庫的同步更新的。

           

          (實例1):

          舉個最簡單的一對多父子關系。那么代碼就寫成:

          父親中的關系映射

          {set name="children" lazy="true" inverse="true"}
                
          {key column="parent_id"/}
                
          {one-to-many class="test.Child"/}
          {/set}

           

          兒子中關系映射

          {many-to-one name="parent" column="parent_id" not-null="true"/}

           


           

          Parent p = new Parent();
          Child c 
          = new Child();
          c.setParent(p);  
          //維護父子之間關系
          p.getChildren().add(c);

          session.save(p);
          session.flush();

           

          注意:{many-to-one}總是設成“inverse=false”的,而且這個屬性在Mapping中是不存在的!

          這樣運行的下來的結果就是:

          Hibernate: insert into parent (id) values (?)
          Hibernate: insert into child (parent_id, id) values (?, ?)

          那么假如c.setParent(p)注釋掉,結果就是:

          Hibernate: insert into parent (id) values (?)

           

          ===================================================

          (實例2):

          一個Person可以參加多個Event,一個Event有多個Person參加。
          映射文件如下:

          <!-- Person.hbm.xml -->
          <
          hibernate-mapping package="events">
            
          <class name="Person" table="person">
                
          <id name="id" column="person_id">
                    
          <generator class="native"/>
                
          </id>
                
          <property name="age" length="0"/>
                
          <property name="firstname"/>
                
          <property name="lastname"/>
                
          <set name="events" table="person_event">
                    
          <key column="person_id"/>
                    
          <many-to-many column="event_id" class="events.Event"/>
                
          </set>
            
          </class>
          </hibernate-mapping>

          <!-- Event.hbm.xml -->
          <
          hibernate-mapping>
            
          <class name="events.Event" table="events">
                
          <id name="id" column="event_id">
                      
          <generator class="native"/>
                
          </id>
                
          <property name="date" column="events_date" type="timestamp"/>
                
          <property name="title" column="events_title"/>
                
          <set name="participants" table="person_event" inverse="true">
                    
          <key column="event_id"/>
                    
          <many-to-many column="person_id" class="events.Person"/>
                
          </set>
            
          </class>
          </hibernate-mapping>

          inverse=true的含義: 由雙向關聯另一方維護該關聯,己方不維護該關聯(只能進行查詢操作)。在上述代碼中,由Person方維護該<many-to-many>關系,示例代碼如下(以向Person參與的Event中加入新的Event為例):
                  Session session = HibernateUtil.getSessionFactory().getCurrentSession();
                  session.beginTransaction();
                  Person p 
          = (Person) session.load(Person.class, personId);
                  Event e 
          = (Event) session.load(Event.class, eventId);
                  p.getEvents().add(e);//執行該代碼時,hibernate會向中間表 person_event中插入person_id和event_id記錄,如果換成e.getParticipants().add(p)的話,該代碼將不會被執行,即hibernate不會向表person_event中插入記錄。
                  session.getTransaction().commit();


          要注意的一點:在雙向關聯的關系中,映射的column(和table)的值要一致(即要用相同的表名和列名),不然設置為inverse="true"的這方將失去這個雙向關系,而變成了一個單向關聯。

          二、Inverse和Cascade的比較

          Inverse:負責控制關系,默認為false,也就是關系的兩端都能控制,但這樣會造成一些問題,更新的時候會因為兩端都控制關系,于是重復更新。一般來說有一端要設為true。
          Cascade:負責控制關聯對象的級聯操作,包括更新、刪除等,也就是說對一個對象進行更新、刪除時,其它對象也受影響,比如我刪除一個對象,那么跟它是多對一關系的對象也全部被刪除。
          舉例說明區別:刪除“一”那一端一個對象O的時候,如果“多”的那一端的Inverse設為true,則把“多”的那一端所有與O相關聯的對象外鍵清空;如果“多”的那一端的Cascade設為Delete,則把“多”的那一端所有與O相關聯的對象全部刪除。

          posted on 2009-12-18 15:17 一杯清茶 閱讀(286) 評論(0)  編輯  收藏 所屬分類: Hibernate

          主站蜘蛛池模板: 上饶市| 明溪县| 巫溪县| 灌南县| 扶风县| 苏尼特右旗| 鄯善县| 普兰店市| 收藏| 社会| 河曲县| 同江市| 安义县| 禹城市| 铜山县| 抚松县| 乐东| 汶川县| 田阳县| 洛宁县| 睢宁县| 聂拉木县| 泌阳县| 吉林省| 大理市| 宜阳县| 朝阳区| 岳西县| 丰都县| 沧源| 卫辉市| 姚安县| 大港区| 铜山县| 奉节县| 渝北区| 仁怀市| 姚安县| 古丈县| 罗定市| 河池市|