文章出處
文章列表
一、一對一關聯
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>
輸出結果如下:
文章列表
全站熱搜