Hibernate的关联关系映射之一对多映射

1. 编写客户和联系人的JavaBean程序(注意一对多的编写规则)

* 客户的JavaBean如下

public class Customer {

private Long cust_id;

private String cust_name;

private Long cust_user_id;

private Long cust_create_id;

private String cust_source;

private String cust_industry;

private String cust_level;

private String cust_linkman;

private String cust_phone;

private String cust_mobile;

//一方中对多方对象的引用

private Set<Linkman> linkmans = new HashSet<Linkman>();

 

}

 

* 联系人的JavaBean如下

public class Linkman {

private Long lkm_id;

private String lkm_name;

private String lkm_gender;

private String lkm_phone;

private String lkm_mobile;

private String lkm_email;

private String lkm_qq;

private String lkm_position;

private String lkm_memo;

//多方中对一方对象的引用

private Customer customer;

 

}

 

4. 编写客户和联系人的映射配置文件(注意一对多的配置编写)

* 客户的映射配置文件如下

<class name="com.itheima.domain.Customer" table="cst_customer">

<id name="cust_id" column="cust_id">

<generator class="native"/>

</id>

<property name="cust_name" column="cust_name"/>

<property name="cust_user_id" column="cust_user_id"/>

<property name="cust_create_id" column="cust_create_id"/>

<property name="cust_source" column="cust_source"/>

<property name="cust_industry" column="cust_industry"/>

<property name="cust_level" column="cust_level"/>

<property name="cust_linkman" column="cust_linkman"/>

<property name="cust_phone" column="cust_phone"/>

<property name="cust_mobile" column="cust_mobile"/>

<!--一对多关系的配置

name:实体类中多方对象集合的属性名

-->

<set name="linkmans">

<!--指定表中关联的外键字段-->

<key column="lkm_cust_id"/>

<!---多方对象的全路径名->

<one-to-many class="com.huge.domain.Linkman"/>

</set>

</class>

 

* 联系人的映射配置文件如下

<class name="com.itheima.domain.Linkman" table="cst_linkman">

<id name="lkm_id" column="lkm_id">

<generator class="native"/>

</id>

<property name="lkm_name" column="lkm_name"/>

<property name="lkm_gender" column="lkm_gender"/>

<property name="lkm_phone" column="lkm_phone"/>

<property name="lkm_mobile" column="lkm_mobile"/>

<property name="lkm_email" column="lkm_email"/>

<property name="lkm_qq" column="lkm_qq"/>

<property name="lkm_position" column="lkm_position"/>

<property name="lkm_memo" column="lkm_memo"/>

<!--多对一关系的配置-->

<many-to-one name="customer" class="com.huge.domain.Customer" column="lkm_cust_id"/>

</class>

 

**技术分析之保存客户和联系人的数据**

1. 进行双向关联进行数据的保存

**技术分析之级联保存**

1. 测试:如果现在代码只插入其中的一方的数据

* 如果只保存其中的一方的数据,那么程序会抛出异常。

* 如果想完成只保存一方的数据,并且把相关联的数据都保存到数据库中,那么需要配置级联!!

* 级联保存是方向性

2. 级联保存效果

* 级联保存:保存一方同时可以把关联的对象也保存到数据库中!!

* 使用cascade="save-update"

 

**技术分析之级联删除**

1. 先来给大家在数据库中演示含有外键的删除客户功能,那么SQL语句是会报出错误的

* 例如:delete from customers where cid = 1;

2. 如果使用Hibernate框架直接删除客户的时候,测试发现是可以删除的

3. 上述的删除是普通的删除,那么也可以使用级联删除,注意:级联删除也是有方向性的!!

* <many-to-one cascade="delete" />

 

**技术分析之级联的取值(cascade的取值)和孤儿删除**

1. 需要大家掌握的取值如下

* none                                                -- 不使用级联

* save-update                                    -- 级联保存或更新

* delete                                              -- 级联删除

* delete-orphan                                  -- 孤儿删除.(注意:只能应用在一对多关系)

* all                                                    -- 除了delete-orphan的所有情况.(包含save-update delete)

* all-delete-orphan                            -- 包含了delete-orphan的所有情况.(包含save-update delete delete-orphan)

2. 孤儿删除(孤子删除),只有在一对多的环境下才有孤儿删除

* 在一对多的关系中,可以将一的一方认为是父方.将多的一方认为是子方.孤儿删除:在解除了父子关系的时候.将子方记录就直接删除。

* <many-to-one cascade="delete-orphan" />

 

**技术分析之让某一方放弃外键的维护,为多对多做准备**

1. 先测试双方都维护外键的时候,会产生多余的SQL语句。

* 想修改客户和联系人的关系,进行双向关联,双方都会维护外键,会产生多余的SQL语句。

* 产生的原因:session的一级缓存中的快照机制,会让双方都更新数据库,产生了多余的SQL语句。

2. 如果不想产生多余的SQL语句,那么需要一方来放弃外键的维护!

* 在<set>标签上配置一个inverse=”true”.true:放弃.false:不放弃.默认值是false

* <inverse="true">

**技术分析之cascade和inverse的区别**

1. cascade用来级联操作(保存、修改和删除)

2. inverse用来维护外键的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值