Sringboot JPA实体类关系映射

本文涉及的产品
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
注册配置 MSE Nacos/ZooKeeper,182元/月
函数计算FC,每月15万CU 3个月
简介: Springboot-Data-JPA是在工作中经常使用到的ORM框架,我觉的比较好用的点是其集成了大量的对数据库的简单操作,基本满足对数据增删改的需要,JPA关系的映射使用注解的方式,很大程度上提高了代码的可读性。 这里的address是一个Address(地址实体类),"JoinColumn"属性会在当前的student表中添加一个addressId字段,这个字段会和"referencedColumnName"设置的"id"属性进行关联(即addressId关联id属性),实现学生实体和地

 文章目录

一、简介

二、关系类型

1.一对一(@OneToOne)

2.一对多(@OneToMany/@ManyToOne)

3.多对多(@ManyToMany)

易发问题


一、简介

       Springboot-Data-JPA是在工作中经常使用到的ORM框架,我觉的比较好用的点是其集成了大量的对数据库的简单操作,基本满足对数据增删改的需要,JPA关系的映射使用注解的方式,很大程度上提高了代码的可读性。

二、关系类型

1.一对一(@OneToOne)

       这里的address是一个Address(地址实体类),"JoinColumn"属性会在当前的student表中添加一个addressId字段,这个字段会和"referencedColumnName"设置的"id"属性进行关联(即addressId关联id属性),实现学生实体和地址实体的一对一关联。

package com.heitao.base.domain;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import javax.persistence.*;
import java.util.Set;
/**
 * @author seaua
 * @description:学生实体类
 * @date 2022/12/7 下午2:52
 * Implements{@link }
 * extend{@link }
 **/
@Entity
public class Student {
    
    /** 
     * PARAM:{@param id} [主键ID] TYPE: {@link Integer}
     */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    /** 
     * PARAM:{@param address} [AddressId] TYPE: {@link Address}
     */
    @OneToOne
    @JoinColumn(name="addressId",referencedColumnName="id")
    private Address address;
    /** 
     * PARAM:{@param clazz} [班级] TYPE: {@link Clazz}
     */
    @ManyToOne
    @JoinColumn(name = "cid")
    @JsonIgnoreProperties("list")
    private Clazz clazz;
    /** 
     * PARAM:{@param course} [课程表] TYPE: {@link Set<Course>}
     */
    @ManyToMany(cascade = {CascadeType.MERGE, CascadeType.REFRESH}, fetch = FetchType.EAGER)
    @JoinTable(name = "stu_cou", joinColumns = {@JoinColumn(name = "stu_id")}, inverseJoinColumns = {@JoinColumn(name = "cou_id")})
    @JsonIgnoreProperties({"student"})
    private Set<Course> courses;
}

image.gif

2.一对多(@OneToMany/@ManyToOne)

       一个班级内有多个学生,多个学生在一个班级内,故学生和班级是多对一,教室和学生是一对多的关系。JPA通过@OneToMany标识一对多,通过@ManyToOne标识多对一。@JoinColum注解用在多的一方,表示在表中添加一个字段与class表的主键ID(默认)产生关联。mappedBy属性用在多方,值为关联实体类中当前类的名称(不可以错),fetch属性表示以积极(FetchType.EAGER)或懒加载(FetchType.LAZY)模式加载,@JsonIgnoreProperties({"clazz"})表示在循环关联时,遇到clazz变量则终止Json解析。

package com.heitao.base.domain;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import javax.persistence.*;
import java.util.List;
/**
 * @author seaua
 * @description:班级-实体类
 * @date 2022/12/7 下午2:52
 * Implements{@link }
 * extend{@link }
 **/
@Entity
public class Clazz {
    /** 
     * PARAM:{@param cid} [主键ID] TYPE: {@link Integer}
     */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer cid;
    /** 
     * PARAM:{@param className} [教室名] TYPE: {@link className}
     */
    private String className;
    /** 
     * PARAM:{@param list} [学生列表] TYPE: {@link list}
     */
    @OneToMany(mappedBy = "clazz",fetch = FetchType.EAGER)
    @JsonIgnoreProperties({"clazz"})
    private List<Student> list;
}

image.gif

3.多对多(@ManyToMany)

       一名学生(Student)可以选修多门课程(Course),一门课程(Course)可以被多个学生选修(Student),课程和学生互为多对多的关系。在Student使用@JoinTable注解来创建多对多中间表,

joinColumns,inverseJoinColumns表示两个关联表中的两个字段名(默认关联主键)。

package com.heitao.base.domain;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import lombok.Getter;
import lombok.Setter;
import org.hibernate.annotations.NotFound;
import org.hibernate.annotations.NotFoundAction;
import javax.persistence.*;
import java.util.Set;
/**
 * @author seaua
 * @description:课程-实体类
 * @date 2022/12/7 下午2:52
 * Implements{@link }
 * extend{@link }
 **/
@Entity
@Getter
@Setter
public class Course {
    /** 
     * PARAM:{@param id} [主键ID] TYPE: {@link Integer}
     */    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    /** 
     * PARAM:{@param courseName} [课程名称] TYPE: {@link String}
     */   
    private String courseName;
    /** 
     * PARAM:{@param students} [学生列表] TYPE: {@link Set<Student>}
     */   
    @ManyToMany(fetch = FetchType.EAGER,mappedBy = "course")
    @NotFound(action = NotFoundAction.IGNORE)
    @JsonIgnoreProperties({"course"})
    private Set<Student> students;
}

image.gif

易发问题

1.为解决依赖关系的死循环问题,使用@JsonIgnoreProperties({"clazz"})注解,{}内为与之关联的变量名称(注意为变量名称)。

2.一对多关系,多端类使用@JoinColumn(name = "cid")注解添加外键字段。多对对关系,任意多端使用@JoinTable(name = "stu_cou", joinColumns = {@JoinColumn(name = "stu_id")}, inverseJoinColumns = {@JoinColumn(name = "cou_id")})注解添加关系联系表,该注解会自动生成一个已两端主键作为关系的主键表。(以上注解表示y生成一个stu_cou表,使用student的主键和coruse的主键作为主键创建关系。)

3.mappedBy的值是关系类的变量名。

目录
相关文章
|
4月前
|
存储 Java 区块链
Springboot应用开发:工具类整理
在实际的Springboot应用开发中,有很多类可作为工具类,这些类将实际开发中可能用到的重复性代码进行提取,方便在后续的开发中使用,在这里我对在开发中经常用到的工具类进行整理,方便自己之后查找,同时希望可以帮助到有实现相关功能的朋友。
228 1
|
4月前
|
存储 Java API
小试牛刀-SpringBoot集成SOL链
java工程师:如何在java/springboot中使用solana区块链呢?不用担心,现在solanaj来了!
111 1
|
4月前
|
监控 Linux 网络安全
Linux命令大全:从入门到精通
日常使用的linux命令整理
732 13
|
4月前
|
安全 Java 数据安全/隐私保护
Springboot应用开发-SpringBootSecurity
Spring Boot Security 是 Spring 提供的安全框架,集成了身份认证和授权功能,帮助开发者快速构建安全的应用程序。本篇博客将从功能介绍到配置和实践,带您全面了解 Spring Boot Security。
796 1
Springboot应用开发-SpringBootSecurity
|
4月前
|
算法 关系型数据库 Java
Springboot集成PostGIS完成路径规划
因为公司里需要做关于林区防火方面的项目,需要完成着火后山区路径的导航,但.....某德的功能似乎只能到达山区的边上,后边的路就需要自己完成导航了。搞了一个周终于有所效果了,也遇见了很多的坑,在此记录一下,希望以后不要踩坑。需要上述的环境才能进行路径导航,环境的搭建可以参阅
120 5
|
4月前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习模型、算法与应用的全方位解析
深度学习,作为人工智能(AI)的一个重要分支,已经在多个领域产生了革命性的影响。从图像识别到自然语言处理,从语音识别到自动驾驶,深度学习无处不在。本篇博客将深入探讨深度学习的模型、算法及其在各个领域的应用。
652 3
|
4月前
|
监控 Java 开发工具
Springboot秒集成-视频推拉流
在工作中需要用到视频的推拉流服务,刚开始准备使用netty服务自己实现RTSP推拉流服务,但在RTSP解包时卡住,自己实现难度确实有点大,后来在网上找到了Zlm4j库,它是基于ZLMediaKit服务实现的Jna版本,可以很容易的集成到Springboot中,在此也。希望本篇博客可以帮助到想快速实现视频推拉流服务的朋友。
413 10
|
4月前
|
IDE Java 开发工具
IntelliJ IDEA 使用技巧与插件推荐
IntelliJ IDEA 是一个功能强大、扩展性丰富的开发工具。通过掌握常用的快捷键和技巧,结合合适的插件,可以大幅提升你的开发效率。
165 2
|
4月前
|
传感器 定位技术 数据格式
常用通信协议及数据格式
常用通信协议和格式总结
361 2
|
4月前
|
NoSQL Java 区块链
Springboot应用开发:配置类整理
在使用SpringBoot进行应用开发中,通常需要编写很多的配置类,这些配置类在很大程度上提高了应用的开发速度.其中就包括线程池、数据库连接池、缓存的相关配置类。在这里我将经常用到的配置类进行整理和总结。
208 1