实例:一个人一个身份证
每一个持久化类中加了一个对方类的引用变量作为属性
或者我们可把一对多的外键唯一就行,即:外键不出现多次,比如学生表的外键cid为1,那么不能出现第二个学生的外键再为1了,此时就说明一个班级对应一个学生
映射文件Student.hbm.xml
把一对多变成一对一,只需要在映射文件中设置一个属性,
因为下面客户端是通过在学生类对象建立关联,所以需要经过Student.hbm.xml文件操作数据库,所以为了保证一对一,就在这个里面设置外键只能出现一次
<hibernate-mapping>
<class name="com.itheima12.hibernate.domain.Student">
<id name="sid" length="5">
<generator class="increment"></generator>
</id>
<property name="description" length="50"></property>
<property name="name" length="20"></property>
<!--
外键
column
unique外键只能出现一次
-->
<many-to-one name="classes" column="cid" class="com.itheima12.hibernate.domain.Classes"
unique="true"
cascade="save-update"></many-to-one>
</class>
</hibernate-mapping>
客户端
student表
班级表
进行一个更新操作(同时把两个学生还没有外键,进行外键更新操作,
建立关联:是把一个班级同时放入两个学生类对象的Classes属性中)
public void testBuildR(){
Transaction transaction = session.beginTransaction();
//把sid为1和2的学生,把cid为1的班级提取出来
Student student1 = (Student)session.get(Student.class, 1L);
Student student2 = (Student)session.get(Student.class, 2L);
Classes classes = (Classes)session.get(Classes.class, 1L);
student1.setClasses(classes);
student2.setClasses(classes);
transaction.commit();
session.close();
}
上面的客户端操作就会报错,原因:一个班级cid作为外键,不能出现在两个学生中
注意:数据库中的表的关系一旦生成,就不会改变,除非人为改变,删除表生成新的关系
private Long cid; //标示符属性
private String name; //一般属性
private String description;
private Set<Student> students; // 关联对象
private String name; //一般属性
private String description;
private Set<Student> students; // 关联对象