為了簡潔,我們創建兩張表分別是Student和Certificate,它們只有主鍵ID和另外一個對象的引用標識符。
從student可以加載certificate。單向
Certificate Student.getCer();//返回Certificate對象
Student Certificate.gerStu();//返回Student對象
1.主鍵關聯
所謂以主鍵關聯,是指兩張數據庫表通過主鍵取得一對一的關聯關系,也就是說一張表的主鍵是引用另一張表的外鍵。例如,對于Student和Certificate對象,一般來說是Student是主體,Certificate對象依附Student存在。它們主鍵關聯的一對一關系就是在數據庫中Student和Certificate表使用相同的主鍵值,這個由Student對象生成。Certificate應用這個主鍵值。它們共享同一主鍵值,這通過在Certificate表中設置外鍵來實現。
一對一主鍵關聯映射中默認cascade="true";
2.一對一以主鍵關聯的使用
既然它們是共用一個主鍵值,關鍵是如何讓另一張表引用已經生成的主鍵值。這在Hibernate中使用的是主鍵的foreign生成機制。
下面是Student和Certificate類的配置源碼。
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="String"><!--映射學生名-->
<property name="carId" type="String"><!--映射映射號-->
<property name="age" type="int"><!--映射學生年齡-->
<one-to-one name="cer"
class="model.Certificate"
fetch="join" cascade="all" constrained="true"/><!--映射文件的身份證對象-->
</class>
</hibernate-mapping>
以上的one-to-one設置為cascade="all",表示增加、刪除、及修改Student對象時,都會級聯增加、刪除、修改Certificate對象。
constrained="true"約束這句話也要加上
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>
</genetator>
</id>
<property name="describe" column="describe"type="String">
</class>
</hibernate-mapping>
上述的兩個配置文件在one-to-one中都沒有設置column屬性(其實他本身就沒有column屬性)。兩個表是通過主鍵值得以連接的?,F在建立一個學生和身份證對象,將他們設置為一對一關聯存入數據庫。
//建立身份證
Certificate cer = new Certificate();
cer.setDescribe("spark");
//新建學生
Student stu = new Student();
stu.setName("spark");
stu.setCardid("10001");
stu.setAge(22);
//設置學生和身份證之間的關聯
stu.setCer(cer);
StudentDAO.saveObj(stu);