文章出處

一、一對一關聯

Hibernate提供了兩種映射一對一關聯關系的方式:按照外鍵映射和按照主鍵映射。下面以員工賬號和員工檔案表為例,介紹這兩種映射方式,并使用這兩種映射方式分別完成以下持久化操作:

(1)保存員工檔案的同時分配給員工一個賬號。

(2)加載員工檔案的同時加載賬號信息。

按照外鍵映射:

關系圖:

①創建實體類:Resume、Users 并封裝屬性

public class Resume {
    //檔案id
    private Integer resid;
    //檔案名稱
    private String resname;
    //檔案編號
    private String rescardno;
    //員工對象
    private Users users;
}
public class Users {
   //員工id
    private Integer userid;
    //員工姓名
    private String username;
    //員工密碼
    private String userpass;
    //檔案對象
    private Resume resume;
}

② 配置小配置 Users.hbm.xml

:property-ref="users" 表明Resume的users屬性建立了從Users對象到Resume對象的關聯

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.happy.entity">
   <class name="Users" table="USERS1">
     <id name="userid" column="USERID" >
         <generator class="native"></generator>
     </id>
     <property name="username" column="USERNAME" type="string"></property>
     <property name="userpass" column="USERPASS" type="string"></property>
    <!-- 配置一對一外鍵關系的關聯 -->
     <one-to-one name="resume" class="Resume" property-ref="users"></one-to-one>
   </class>
</hibernate-mapping>

Resume.hbm.xml

注:因為Resume為外鍵表 植入<many-to-one>元素 并設置屬性unique=“true” 確保用戶檔案的列只能是唯一的, 一個檔案對應一個用戶編號

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
                            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.happy.entity">
 <class name="Resume" table="RESUME1">
  <id column="RESID" name="resid">
   <generator class="native"></generator>
  </id>
  <property column="RESNAME" name="resname" type="string"/>
  <property column="RESCARDNO" name="rescardno" type="string"/>
  <!--主的一方  -->
  
  <!-- 在用戶檔案指定的列只能是唯一的   一個檔案只能對應一個用戶編號-->
  <many-to-one  name="users" cascade="all" class="Users" column="RESCARDID" unique="true"/>
 </class>
</hibernate-mapping>

③ 大配置進行關聯小配置

<!-- 關聯小配置 -->
        
<mapping resource="cn/happy/entity/Users.hbm.xml" /> 
<mapping resource="cn/happy/entity/Resume.hbm.xml" />

測試類:

 

     /*
     * 添加
     */
    
    @Test
    public void addTest(){
        //創建用戶對象
        Users u=new Users();
        u.setUsername("張三1");
        u.setUserpass("003");
        //創建檔案對象
        Resume r=new Resume();
        r.setResname("大學文憑1");
        r.setRescardno("003");
        //關聯
        u.setResume(r);
        r.setUsers(u);
        //保存檔案,員工自動save
        session.save(r);
        System.out.println("save ok!!!");
    
    }

 

輸出結果:

按照主鍵映射:

關系圖如下:

實體類同上

其次就是小配置的更改。Resume為主鍵表,Users的Userid既是主鍵又是外鍵 因此植入元素generator的類型為foreign主鍵

<one-to-one>植入屬性constrained 用來約束 在底層數據表中植入外鍵

Users.hbm.xml配置文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.happy.pk">
   <class name="Users2" table="USERS2">
     <id name="userid" column="USERID" >
         <generator class="foreign">
            <param name="property">resume2</param>
         </generator>
     </id>
     <property name="username" column="USERNAME" type="string"></property>
     <property name="userpass" column="USERPASS" type="string"></property>
     <!-- constrained:用來約束 在底層USERS2數據表中,植入外鍵-->
     <one-to-one name="resume2" class="Resume2" constrained="true"></one-to-one>
   </class>
</hibernate-mapping>

Resume.hbm.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
                            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.happy.pk">
 <class name="Resume2" table="RESUME2">
  <id column="RESID" name="resid">
     <generator class="sequence">
       <param name="sequence">SEQ_NUM</param>
     </generator>
  </id>
  <property column="RESNAME" name="resname" type="string"/>
  <property column="RESCARDNO" name="rescardno" type="string"/>
  <!--主的一方  -->
  <one-to-one  name="users2" cascade="all" class="Users2" />
 </class>
</hibernate-mapping>

輸出結果如下:


 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()