jpa中的表关系以及多表CRUD操作

一对多的关系映射

第一步 明确两张表的关系

一个客户可以对应多个联系人
多个联系人可以属于同一个客户

第二步 在数据库中建立两张表的关系

使用外键。
在联系人表中添加一列,这一列的值来源于 客户表的主键,添加的这列
是外键。

第三步 在实体类中建立两个实体间的关系

从表:
多对一的关系映射:多个联系人对应一个客户
所以,从表实体包含主表的对象引用

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);
	
	
	
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值