Spring - JPA 一对一, 一对多, 多对多关联

现在有三个类:One Many Much

One类
Much类

@Entity
public class Much {

	@Id
	@GeneratedValue
	private Integer id;

	private String name;

	@ManyToMany
	@JoinTable(
			name = "much_more",
			joinColumns= {@JoinColumn(name = "many_id", referencedColumnName = "id")},
			inverseJoinColumns= {@JoinColumn(name = "much_id", referencedColumnName = "id")})
	private List<Many> manys;

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public List<Many> getManys() {
		return manys;
	}

	public void setManys(List<Many> manys) {
		this.manys = manys;
	}

}

  

@Entity public class One { @Id @GeneratedValue private Integer id; private String name; // one to many @OneToMany(cascade = CascadeType.ALL, mappedBy = "one") // @JoinColumn(name = "many_id") private List<Many> manys; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }

  

Many类

@Entity
public class Many {

	@Id
	@GeneratedValue
	private Integer id;

	private String name;

	@ManyToOne(fetch = FetchType.EAGER)
	@JoinColumn(name = "one_id")
	private One one;

	public Integer getId() {
		return id;
	}

	@ManyToMany(mappedBy="manys")
	private List<Much> muchs;

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public List<Much> getMuchs() {
		return muchs;
	}

	public void setMuchs(List<Much> muchs) {
		this.muchs = muchs;
	}

	public One getOne() {
		return one;
	}

	public void setOne(One one) {
		this.one = one;
	}
}

  

一对一:现有一个single类和One是一对一关系,则只需要在SIngle类中添加如下即可

@OneToOne(fetch = FETCHTYPE.EAGE)
private One one;

  此时生成的表结构是: 在Single表中有一个one_id字段指向one表的主键

一对多: 一个one对应多个many,

    首先在一端添加:

@OneToMany(cascade = CascadeType.ALL, mappedBy = "one") //mappedBy = "one" 表示one是一对多管理的被维护端, 既当添加many时顺带添加一个one
private List<Many> manys;

  

  然后再多端添加:

@ManyToOne(fetch = FetchType.EAGER) @JoinColumn(name = "one_id") // 在多端(从表的外键)添加外键字段指向一端(主表的主键)的主键字段
private One one;

  

此时生成的表结构是:在Many表里有一个one_id外键指向一端One

多对多:

  拿many和much来说, 他们多对多关系, 我们先确定谁是多放关系的维护端,这里我指定Much为多方关系的维护端。

  多对多关系中,hibernate会自动生成中间表。

  在Much中添加:

Much类

	@ManyToMany
	@JoinTable(  // JoinTable所在的一端为多方关系的维护端
			name = "much_more", // 指定中间表名
			joinColumns= {@JoinColumn(name = "many_id", referencedColumnName = "id")}, // 指定当前表在中间表的外键名称和外键所指向的当前表主键
			inverseJoinColumns= {@JoinColumn(name = "much_id", referencedColumnName = "id")} // 指定另一方在中间表的外键名称和外键所指向的主键
           )
	private List<Many> manys;

  然后在多方关系的被维护端Many中添加:

@ManyToMany(mappedBy="manys") // mappedBy指定many为多方关系的被维护端
private List<Much> muchs;

  此时生成的表结构是:生成一个中间表叫much_more, 外键字段叫much_id,more_id分别指向两个表的主键

欢迎大家指正。

时间: 2024-08-09 06:21:47

Spring - JPA 一对一, 一对多, 多对多关联的相关文章

mybatis 一对一 一对多 多对多

一对一 一对多 多对多 原文地址:https://www.cnblogs.com/cwone/p/11909271.html

SQLAlchemy_定义(一对一/一对多/多对多)关系

目录 Basic Relationship Patterns One To Many One To One Many To Many Basic Relationship Patterns 基本关系模式 The imports used for each of the following sections is as follows: 下列的 import 语句,应用到接下来所有的代章节中: from sqlalchemy import Table, Column, Integer, Forei

django mysql 表的一对一 一对多 多对多

表结构的设计 一对一 多对一  将key写在多 多对多 外键: 描述  多对一的关系 写在多的一方 class Book(models.Model) title = models.CharField(max_length=32,unique=Ture) publisher = models.ForeignKey (to=Publisher,on_deleete=models.CASADE) publisher = models.ForeignKey(to='Publisher', on_dele

表关系(一对一,一对多,多对多)

可以在数据库图表中的表之间创建关系,以显示一个表中的列与另一个表中的列是如何相链接的. 在一个关系型数据库中,利用关系可以避免多余的数据.例如,如果设计一个可以跟踪图书信息的数据库,您需要创建一个名为 titles 的表,它用来存储有关每本书的信息,例如书名.出版日期和出版社.您也可能保存有关出版社的信息,诸如出版社的电话.地址和邮政编码.如果您打算在 titles 表中保存所有这些信息,那么对于某出版社出版的每本书都会重复该出版社的电话号码. 更好的方法是将有关出版社的信息在单独的表,publ

Hibernate 映射文件的配置 核心文件的配置 一对一 一对多 多对多 hibernate实现分页 Hibernate中session的关闭问题总结

以留言系统为实例 1 .配置映射文件:首先得引入约束dtd <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 然后<hibernate-mapping></hibernate-mapping>映射标签 <

MyBatis 一对多,多对一关联查询的时候Mapper的顺序

要先写association,然后写collection:这是由DTD决定的: <resultMap ...> <association ...> </association> <collection ...> </collection > </resultMap>

关于JPA一对一,一对多(多对一),多对多的详解

一.@OneToOne关系映射 JPA使用@OneToOne来标注一对一的关系. 实体 People :用户. 实体 Address:家庭住址. People 和 Address 是一对一的关系. 这里用两种方式描述JPA的一对一关系. 一种是通过外键的方式(一个实体通过外键关联到另一个实体的主键): 另外一种是通过一张关联表来保存两个实体一对一的关系. 1.通过外键的方式 people 表(id,name,sex,birthday,address_id) address 表(id,phone,

多对多 一对一 一对多 主从 关联 字典

 "订单"表中的主键.  "产品"表中的主键.  一个订单可以包含多种产品 ...   ... 且每种产品可以出现在多个订单上.   课程文本 在多对多关系中,一个表中的一个记录与第二个表中的多个记录相关,第二个表中的一个记录与第一个表中的多个记录相关. 这种类型的关系需要一个称为连接表的第三个表.连接表包含另两个表中的主键,并将它们用作其外键. 例如,"订单"表和"产品"表具有多对多关系.一个订单可以包含多种产品,每种产品可

Mybatis 一对一、一对多、多对多关联

示例项目:MIPO_CRM 一.一对一关联 示例:订单与销售机会 描述:在业务员与客户的联系人的联系记录中可以生成一条销售机会,而此条销售机会可生成一条订单,两者呈一对一关联. 1.表设计 opportunity(销售机会) orders(订单) 2.pojo Opportunity /** * 销售机会机会 * @author Administrator * */ public class Opportunity implements Serializable{ private int opi