hibernate的一对一双向操作

实例:一个人一个身份证

每一个持久化类中加了一个对方类的引用变量作为属性

或者我们可把一对多的外键唯一就行,即:外键不出现多次,比如学生表的外键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(){
Session session = sessionFactory.openSession();
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;  //
关联对象

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值