隨筆 - 6  文章 - 129  trackbacks - 0
          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(14)

          隨筆檔案(6)

          文章分類(467)

          文章檔案(423)

          相冊

          收藏夾(18)

          JAVA

          搜索

          •  

          積分與排名

          • 積分 - 829345
          • 排名 - 49

          最新評論

          閱讀排行榜

          評論排行榜

            一對一關系在實際生活中是比較常見的,如果學生與身份證的關系,學生與檔案的關系等等。
            一對一關系在Hibernate中的實現有兩種方式,分別是主鍵關聯外鍵關聯

          以主鍵關聯

            主鍵關系的重點是:關聯的兩個實體共享一個主鍵值。
          Student.hbm.xml
          ...
          <hibernate-mapping>
           <class name="model.Student" table="student" lazy="true"><!--把類和表關聯起來-->
            <id name="id" unsaved-value="null"><!--id的產生方式是uuid.hex-->
             <generator class="uuid.hex"/>
            </id>
            <property name="name" type="sring"/>
            <one-to-one name="cer"
              class="model.Certificate"
              fetch="join"
              cascade="all"
            /><!--映射對應的身份證對象-->
           </class>
          </hibernate-mapping>

          Certificate.hbm.xml
          ...
          <hibernate-mapping>
           <class name="model.Certificate" table="certificate" lazy="true">
            <id name="id">
            <!--外鍵生成機制,引用stu對象的主鍵作為certificate數據表的主鍵和外鍵-->
             <generator class="foreign">
              <param name="property">stu</param>
             </generator>

            </id>
            <one-to-one name="stu"
              class="model.Student"
              constrained="true" <!--表示Certificate引用了stu的主鍵作為外鍵-->
            />
           </class>
          </hibernate-mapping>

          上述的兩個配置文件在<one-to-one>標簽中都沒有設置column屬性
          (實際上<one-to-one>標簽本身就沒有column屬性)。


          以外鍵關聯

            以外鍵關聯的重點是:兩個實體各自有不同的主鍵,但其中一個實體有一個外鍵引用
          了另一個表的主鍵。

          Student.hbm.xml
          ...
          <hibernate-mapping>
           <class name="model.Student" table="student" lazy="true">
            <id name="id" nusaved-value="null">
             <generator class="uuid.hex"/>
            </id>
            <property name="name" type="sring"/>
            <one-to-one name="cer"
              class="model.Certificate"
              fetch="join"
              cascade="all"
            /><!--映射對應的身份證對象-->
           </class>
          </hibernate-mapping>
          可以看到Student.hbm.xml和以主鍵關聯時的代碼是一樣的,并沒有改變。

          Certificate.hbm.xml
          ...
          <hibernate-mapping>
           <class name="model.Certificate" table="certificate" lazy="true">
            <id name="id">
             <generator class="uuid.hex"/> <!--不再是foreign了-->
            </id>
            <many-to-one name="stu"
              class="model.Student"
              unique="true" <!--唯一的多對一,其實也就變成了一對一關系-->
              column="stu_id" 
            />

           </class>
          </hibernate-mapping>
          以外鍵關聯的一對一,其實本質上變成了一對多的雙向關聯了,編寫時直接
          按照一對多和多對一的要求編寫,最后在many-to-one這一邊上加上一個
          unique="true"即可。



          posted on 2007-12-29 14:00 Ke 閱讀(1773) 評論(0)  編輯  收藏 所屬分類: hibernate
          主站蜘蛛池模板: 洛南县| 三门县| 怀柔区| 沾化县| 滨州市| 定结县| 崇礼县| 涟源市| 柏乡县| 大英县| 永靖县| 涿鹿县| 无为县| 琼中| 桦川县| 塔河县| 峨边| 夏河县| 正安县| 边坝县| 夏邑县| 富锦市| 文水县| 木里| 宁明县| 凤阳县| 商都县| 蕲春县| 张家口市| 苏尼特左旗| 临朐县| 天气| 长宁县| 双辽市| 新蔡县| 岳池县| 旬邑县| 西和县| 时尚| 额济纳旗| 辉县市|