一对一关联
Hibernate提供了两种映射一对一关联关系的方式:按照外键映射和按照主键映射。下面以员工账号和员工档案表为例,介绍这两种映射方式,并使用这两种映射方式分别完成以下持久化操作:
(1)保存员工档案的同时分配给员工一个账号。
(2)加载员工档案的同时加载账号信息。
按照外键映射:
关系图:
①创建实体类:Resume、Users 并封装属性
1 public class Resume { 2 //档案id 3 private Integer resid; 4 //档案名称 5 private String resname; 6 //档案编号 7 private String rescardno; 8 //员工对象 9 private Users users; 10 }
1 public class Users { 2 //员工id 3 private Integer userid; 4 //员工姓名 5 private String username; 6 //员工密码 7 private String userpass; 8 //档案对象 9 private Resume resume; 10 }
② 配置小配置 Users.hbm.xml
注:property-ref="users" 表明Resume的users属性建立了从Users对象到Resume对象的关联
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE hibernate-mapping PUBLIC 3 "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 4 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 5 <hibernate-mapping package="cn.happy.entity"> 6 <class name="Users" table="USERS1"> 7 <id name="userid" column="USERID" > 8 <generator class="native"></generator> 9 </id> 10 <property name="username" column="USERNAME" type="string"></property> 11 <property name="userpass" column="USERPASS" type="string"></property> 12 <!-- 配置一对一外键关系的关联 --> 13 <one-to-one name="resume" class="Resume" property-ref="users"></one-to-one> 14 </class> 15 </hibernate-mapping>
Resume.hbm.xml
注:因为Resume为外键表 植入<many-to-one>元素 并设置属性unique=“true” 确保用户档案的列只能是唯一的, 一个档案对应一个用户编号
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 4 <hibernate-mapping package="cn.happy.entity"> 5 <class name="Resume" table="RESUME1"> 6 <id column="RESID" name="resid"> 7 <generator class="native"></generator> 8 </id> 9 <property column="RESNAME" name="resname" type="string"/> 10 <property column="RESCARDNO" name="rescardno" type="string"/> 11 <!--主的一方 --> 12 13 <!-- 在用户档案指定的列只能是唯一的 一个档案只能对应一个用户编号--> 14 <many-to-one name="users" cascade="all" class="Users" column="RESCARDID" unique="true"/> 15 </class> 16 </hibernate-mapping>
③ 大配置进行关联小配置
1 <!-- 关联小配置 --> 2 <mapping resource="cn/happy/entity/Users.hbm.xml" /> 3 <mapping resource="cn/happy/entity/Resume.hbm.xml" />
测试类:
1 /* 2 * 添加 3 */ 4 @Test 5 public void addTest(){ 6 //创建用户对象 7 Users u=new Users(); 8 u.setUsername("张三1"); 9 u.setUserpass("003"); 10 //创建档案对象 11 Resume r=new Resume(); 12 r.setResname("大学文凭1"); 13 r.setRescardno("003"); 14 //关联 15 u.setResume(r); 16 r.setUsers(u); 17 //保存档案,员工自动save 18 session.save(r); 19 System.out.println("save ok!!!"); 20 21 }
按照主键映射:
关系图如下:
实体类同上
其次就是小配置的更改。Resume为主键表,Users的Userid既是主键又是外键 因此植入元素generator的类型为foreign主键
<one-to-one>植入属性constrained 用来约束 在底层数据表中植入外键
Users.hbm.xml配置文件如下:
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE hibernate-mapping PUBLIC 3 "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 4 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 5 <hibernate-mapping package="cn.happy.pk"> 6 <class name="Users2" table="USERS2"> 7 <id name="userid" column="USERID" > 8 <generator class="foreign"> 9 <param name="property">resume2</param> 10 </generator> 11 </id> 12 <property name="username" column="USERNAME" type="string"></property> 13 <property name="userpass" column="USERPASS" type="string"></property> 14 <!-- constrained:用来约束 在底层USERS2数据表中,植入外键--> 15 <one-to-one name="resume2" class="Resume2" constrained="true"></one-to-one> 16 </class> 17 </hibernate-mapping>
Resume.hbm.xml配置如下:
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 4 <hibernate-mapping package="cn.happy.pk"> 5 <class name="Resume2" table="RESUME2"> 6 <id column="RESID" name="resid"> 7 <generator class="sequence"> 8 <param name="sequence">SEQ_NUM</param> 9 </generator> 10 </id> 11 <property column="RESNAME" name="resname" type="string"/> 12 <property column="RESCARDNO" name="rescardno" type="string"/> 13 <!--主的一方 --> 14 <one-to-one name="users2" cascade="all" class="Users2" /> 15 </class> 16 </hibernate-mapping>