文章目录
一对多的关系映射
第一步 明确两张表的关系
一个客户可以对应多个联系人
多个联系人可以属于同一个客户
第二步 在数据库中建立两张表的关系
使用外键。
在联系人表中添加一列,这一列的值来源于 客户表的主键,添加的这列
是外键。
第三步 在实体类中建立两个实体间的关系
从表:
多对一的关系映射:多个联系人对应一个客户
所以,从表实体包含主表的对象引用
private Customer customer;
主表:
1.一对多关系映射:一个客户对应多个联系人
主表中包含从表实体的引用集合
private Set<LinkMan> linKmans = new HashSet(0);
第四步 关联关系维护的放弃
主表:
@OneToMany(targetEntity=LinkMan.class,mappedBy=”customer”)
Private Set<LinkMan> linkmans = new HashSet(0);
关联关系的维护:
在多表关系中,有一个很重要的概念叫做关联关系维护,也就是你中有我,我中有你,当一方数据有变动时会想着让对方也做相关的更新,但是这个事如果二者都去考虑操作比较不合理,那么我干脆让一方去维护这个事情,让谁呢? 让多的一方,也就是从表,因为他只需要维护一个对象 客户。
mappedBy: 关联关系维护,这个属性指向谁,就让谁放弃维护关联关系,如果不加,则会出现第三张表
从表:
@ManyToOne(targetEntity=Customer.class)
@JoinColumn(name=”lkm_cust_id”,referencedColumnName=”cust_id”)//增加一列外键列
实体类
主表类
package domain;
import java.io.Serializable;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
/**
* <p>Title: Customer</p>
* <p>Description: 客户的实体类</p>
* @author zhaocq
* @date 2018年9月19日
*/
@Entity
@Table(name="cst_customer")
public class Customer implements Serializable {
@Id
@Column(name="cust_id")
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Integer custId;
@Column(name="cust_name")
private String custName;
@Column(name="cust_source")
private String custSource;
@Column(name="cust_industry")
private String custIndustry;
@Column(name="cust_level")
private String custLevel;
@Column(name="cust_address")
private String custAddress;
@Column(name="cust_phone")
private String custPhone;
// 一对多(客户表中要包含一个联系集合)
@OneToMany(targetEntity=LinkMan.class,mappedBy="customer",cascade=CascadeType.REMOVE,fetch=FetchType.EAGER)
private Set<LinkMan> linkMams = new HashSet(0);