hibernate学习(五)
hibernate的一对多关联映射:
一、数据库表与表之间关系
一对多建表原则:
多对多的建表原则:
一对一建表原则:
(1)唯一外键对应:
(2)主键对应:
二、hibernate 一对多的关系配置:
(1)创建实体
1:一的一方的实体,放置多的一方的集合。
2:多的一方的实体,创建一的一方的对象
(2)创建映射文件:
1.联系人映射的创建:
2.客户映射的创建:
三、创建核心配置文件:
1:引入两个映射:
2:引入工具类(略)
3:编写测试类:
四、hibernate一对多相关操作:
1:一对多关系保存一边是否可以:
2:一对多的级联操作:
保存客户级联联系人:
保存联系人级联客户:
3:测试对象的导航:
4:级联删除:
(1)先建表,在删除。
(2)默认的情况:先把联系人的外键设置为空,在删除客户和联系人
(3)先从customer的映射文件中配置cascade=delete
(4)删除联系人级联删除客户(基本不用,不太符合实际情况)
五、一对多设置了双向关联产生多余的SQL语句
产生两次多余的SQL语句
联系人映射里面的客户更新的就是lkm_cust_id外键,客户映射里面的联系人更新的也就是lkm_cust_id外键,都更新了外键,就是两边都能维护这个外键。造成了数据库中资源的浪费。
一般是多的一方放弃维护权:举个例子,让老师记住很多班的学生,老师根本记不住,那么直接让老师放弃。学生记老师的名字很好记。多的一方是学生,记老师名字很好记,一的一方是老师,记学生的名字不好记,所以可以一的一方放弃。true就是放弃维护权的意思,false就是不放弃维护权。
区分cascade和inverse的区别
cascade只管插入和关联数据,inverse管外键。