潍坊手机网站本机网络ip做网站
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管外键。

