posts - 66,  comments - 11,  trackbacks - 0
          由于多對多的性能不佳(由于引入了中間表,一次讀取操作需要反復(fù)數(shù)次查詢),因才在設(shè)計(jì)中應(yīng)該避免大量使用。同時(shí),在多對多關(guān)系中,應(yīng)根據(jù)情況,采取延遲加載機(jī)制來避免無謂的性能開銷。
          <?xml version="1.0" encoding="utf-8"?>
          <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
          >
          <hibernate-mapping>
              
          <class name="com.redsage.hibernate.db.entity.TGroup" table="t_group" dynamic-insert="false" dynamic-update="false">
                  
          <id name="id" column="id"  type="java.lang.Integer">
                      
          <generator class="native"></generator>
                  
          </id>
                  
          <set name="roles" table="t_gourp_role" lazy="false" inverse="false" cascade="save-update">
                      
          <key column="group_id"></key>
                      
          <many-to-many class="com.redsage.hibernate.db.entity.TRole" column="role_id"></many-to-many>
                  
          </set>
              
          </class>
          </hibernate-mapping>
          1、t_gourp_role為t_group和t_role之間的映射表,它保存了group和role之間的映射關(guān)系。
          2、一般情況下,cascade應(yīng)該設(shè)置為"save-update",對于多對多邏輯而言,很少出現(xiàn)刪除一方需要級聯(lián)刪除所有關(guān)聯(lián)數(shù)據(jù)的情況,如刪除一個(gè)Group,一般不會(huì)刪除其包含的Role,反之刪除Role一般也不會(huì)刪除其所關(guān)聯(lián)的所有Group.
          3、映射表中對于t_group表記錄的標(biāo)示字段。
          4、映射表中對于t_role表記錄的標(biāo)示字段。

          <?xml version="1.0" encoding="utf-8"?>
          <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
          >
          <hibernate-mapping>
              
          <class name="com.redsage.hibernate.db.entity.TRole" table="t_role" dynamic-insert="false" dynamic-update="false">
                  
          <id name="id" column="id"  type="java.lang.Integer">
                      
          <generator class="native"></generator>
                  
          </id>
                  
          <set name="groups" table="t_gourp_role" lazy="false" inverse="true" cascade="save-update">
                      
          <key column="role_id"></key>
                      
          <many-to-many class="com.redsage.hibernate.db.entity.TGroup" column="group_id"></many-to-many>
                  
          </set>
              
          </class>
          </hibernate-mapping>



          posted on 2009-11-04 17:11 王永慶 閱讀(152) 評論(0)  編輯  收藏 所屬分類: HIBERNATE
          <2009年11月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          關(guān)注blogs

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 闽清县| 博湖县| 天门市| 古田县| 阳西县| 米易县| 孝昌县| 泰兴市| 银川市| 宜兰县| 克什克腾旗| 石棉县| 合水县| 横山县| 石阡县| 大关县| 南充市| 竹溪县| 福清市| 嵊州市| 伊金霍洛旗| 大余县| 木兰县| 长武县| 广州市| 泊头市| 弥勒县| 平邑县| 顺义区| 成都市| 密山市| 大姚县| 成安县| 那曲县| 修水县| 桂阳县| 萨嘎县| 于田县| 含山县| 太湖县| 南平市|