广告
返回顶部
首页 > 资讯 > 后端开发 > Python >SpringDataJPA实体类关系映射配置方式
  • 430
分享到

SpringDataJPA实体类关系映射配置方式

2024-04-02 19:04:59 430人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录springDataJPA1.单向一对一映射2.双向一对一映射3.单向一对多映射4.双向一对多映射5.单向多对一映射6.双向多对一映射7.单向多对多映射8.双向多对多映射Spri

SpringDataJPA


//FetchType.LAZY:懒加载,加载一个实体时,定义懒加载的属性不会马上从数据库中加载
//FetchType.EAGER:急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载
//cascade = CascadeType.ALL 表示所有情况下均进行关联操作,即save-update和delete
@JSONBackReference   //解决循环引用问题
@jsonIgnoreProperties(value = "order") //解决循环引用问题,order内容大,不加载
//双向映射存在转json无限递归问题 需要注解来处理 推荐使用第二个注解 value值为对方表作映射的变量值

1.单向一对一映射

一方


  //教师
  @Id @GeneratedValue(strategy=GenerationType.IDENTITY)
  private int id;
  private String name;
  private long salary;
  @OneToOne 
  @JoinColumn(name="PSPACE_ID") 
  private ParkingSpace parkingSpace;

一方


    //停车场
    @Id @GeneratedValue(strategy=GenerationType.IDENTITY)
    private int id;
    private int lot;
    private String location;

总结

添加时候需要先添加@OneToOne的那方,删除也是。

2.双向一对一映射

一方


  //人员
  @Id
  @GeneratedValue(strategy=GenerationType.IDENTITY)
  private long id;
  private String name;
  @OneToOne
  @JoinColumn(name="DEPT_ID")
  @JsonIgnoreProperties(value = "person")
  private Department department;

一方


  //部门
  @Id
  @GeneratedValue(strategy=GenerationType.IDENTITY)
  private long id;
  private String name;
  @OneToOne(mappedBy="department")
  @JsonIgnoreProperties(value = "department")
  private Person person;

总结


@JsonBackReference   //解决循环引用问题
@JsonIgnoreProperties(value = "order") //解决循环引用问题,order内容大,不加载
//双向映射存在转json无限递归问题 需要注解来处理 推荐使用第二个注解 value值为对方表作映射的变量值

3.单向一对多映射

一方


    @Id
    @GeneratedValue
    private Long id;
    @Column(length = 32)
    private String name;
    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)//级联保存、更新、删除、刷新;延迟加载
    @JoinColumn(name = "author_id")//在book表增加一个外键列来实现一对多的单向关联
    private Set<Book> books = new HashSet<Book>();

多方


    //单向一对多的情况下  多方不需要加任何关联标识
 @Id
    @GeneratedValue
    private Long id;
    @Column(length=32)
    private String name;

总结

因为是单向的关联,多方不需要加任何的关联标识 只需要在一方添加即可

4.双向一对多映射

一方


    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id; //主键
    private String name; //姓名
    //描述客户可以有多个订单
    @OneToMany(mappedBy = "customer", cascade = CascadeType.ALL)
    @JsonBackReference
    private Set<Order> order = new HashSet<Order>();

多方


    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    private Double money;
    private String receiverInfo; //收货地址
    // 订单与客户关联
    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "c_id") //指定外键列  
    @JsonIgnoreProperties(value = "order") //解决循环引用问题,order内容大,不加载
    private Customer customer; //描述订单属于某一个客户

总结


@JsonBackReference   //解决循环引用问题
@JsonIgnoreProperties(value = "order") //解决循环引用问题,order内容大,不加载
//双向映射存在转json无限递归问题 需要注解来处理 推荐使用第二个注解 value值为对方表作映射的变量值

5.单向多对一映射

多方


 @GeneratedValue
 @Id
 private Integer id;
 @Column(name="ORDER_NAME")
 private String orderName;
 //映射单向 n-1的关联关系
 //使用@ManyToOne来映射多对一的关联关系
 //使用@JoinColumn 来映射外键
 //可使用 @ManyToOne 的fetch 属性来修改默认的关联属性的加载策略
 @JoinColumn(name="CUSTOMER_ID")  //此外键为一方的主键
 @ManyToOne(fetch=FetchType.EAGER)
 private Customer customer;

一方


    //单向多对一的情况下,一方不需要加任何关联标识
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Id
    private Integer id;
    private String lastName;
    private String email;
    private int age;
    private Date createdTime;
    private Date birth;

总结

保存多对一时,建议先保存1的一端,后保存n的一端,这样不会多出额外的update语句。

6.双向多对一映射

多方


 @GeneratedValue
 @Id
 private Integer id;
 @Column(name="ORDER_NAME")
 private String orderName;
 //映射单向 n-1的关联关系
 //使用@ManyToOne来映射多对一的关联关系
 //使用@JoinColumn 来映射外键
 //可使用 @ManyToOne 的fetch 属性来修改默认的关联属性的加载策略
 @JoinColumn(name="CUSTOMER_ID")
 @ManyToOne(fetch=FetchType.EAGER)
 @JsonIgnoreProperties(value = {"customer","orders"})
 private Customer customer;

一方


    @GeneratedValue(strategy=GenerationType.AUTO)
    @Id
    private Integer id;
    @Column(name="LAST_NAME",length=50,nullable=false)
    private String lastName;
    private String email;
    private int age;
    //定义日期格式
    @Temporal(TemporalType.TIMESTAMP)
    private Date createdTime;
    @Temporal(TemporalType.DATE)
    private Date birth;
    //映射单向1-n的关联关系
    //使用@OneToMany 映射单向1-n的关联关系
    //使用@JoinColumn 来映射外键的名称
    //可以使用@OneToMany 的 fetch 属性来修改加载策略
    //可以使用@OneToMany 的 cascade 属性来修改默认的删除策略
//    @JoinColumn(name="CUSTOMER_ID")
    //一的一端放弃维持关联关系
    @OneToMany(fetch=FetchType.EAGER,cascade={CascadeType.REMOVE},mappedBy="customer")
    @JsonIgnoreProperties(value = "orders")
    private Set<Order> orders = new HashSet<>();

总结

1.必须使用@JsonIgnoreProperties注解来拦截转json时无限递归的问题

2.若是双向 1-n 的关联关系, 执行保存时:

(1)若先保存 n 的一端, 再保存 1 的一端, 默认情况下, 会多出2n 条 UPDATE 语句;

(2)若先保存 1 的一端, 则会多出 n 条 UPDATE 语句。

(3)故在进行双向 1-n 关联关系时, 建议使用 n 的一方来维护关联关系, 而 1 的一方不维护关联系, 这样会有效的减少 sql 语句(即,N的一端对应的表中使用外键关联1的一端,外键对应1的一端的表主键)

注意:若在 1 的一端的 @OneToMany 中使用 mappedBy 属性, 则 @OneToMany 端就不能再使用 @JoinColumn 属性了。

7.单向多对多映射

多方


   @Id
    @GeneratedValue
    private Long id;
    private String name;
    // 表示多对多
    @ManyToMany(cascade = CascadeType.ALL)
    // 中间表的表名
    @JoinTable(name = "t_user_role", joinColumns = {@JoinColumn(name = "user_id")},
            //反转  user这个表的 反面则是 role
            inverseJoinColumns = {@JoinColumn(name = "role_id")})
    private Set<Role> roles = new HashSet<>();

多方


    @Id
    @GeneratedValue
    private Long id;
    private String name;

总结

使用 @JoinTable 来映射中间表

1. name 指向中间表的名字

2. joinColumns 映射当前类所在的表在中间表中的外键

2.1 name 指定外键列的列名

2.2 referencedColumnName 指定外键列关联当前表的哪一列

3. inverseJoinColumns 映射关联的类所在中间表的外键

8.双向多对多映射

多方


    @Id
    @GeneratedValue
    private Long id;
    private String name;
    // 表示多对多
    @ManyToMany(fetch = FetchType.LAZY,cascade = CascadeType.REMOVE)
    @JoinTable(name="t_user_role",joinColumns={@JoinColumn(name="user_id")},
            inverseJoinColumns ={@JoinColumn(name="role_id")} )
    @JsonIgnoreProperties(value = "users")
    private Set<Role> roles = new HashSet<>()

多方


    @Id
    @GeneratedValue
    private Long id;
    private String name;
    @ManyToMany(fetch = FetchType.LAZY,cascade = CascadeType.ALL)
    @JoinTable(name="t_user_role",joinColumns={@JoinColumn(name="role_id")},
            inverseJoinColumns ={@JoinColumn(name="user_id")} )
    @JsonIgnoreProperties(value = "roles")
    private Set<User> users = new HashSet<>();

总结

使用 @JoinTable 来映射中间表

1. name 指向中间表的名字

2. joinColumns 映射当前类所在的表在中间表中的外键

2.1 name 指定外键列的列名

2.2 referencedColumnName 指定外键列关联当前表的哪一列

3. inverseJoinColumns 映射关联的类所在中间表的外键


@JsonBackReference //解决循环引用问题
@JsonIgnoreProperties(value = "order") //解决循环引用问题,order内容大,不加载

双向映射存在转json无限递归问题 需要注解来处理 推荐使用第二个注解 value值为对方表作映射的变量值

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: SpringDataJPA实体类关系映射配置方式

本文链接: https://www.lsjlt.com/news/159208.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringDataJPA实体类关系映射配置方式
    目录SpringDataJPA1.单向一对一映射2.双向一对一映射3.单向一对多映射4.双向一对多映射5.单向多对一映射6.双向多对一映射7.单向多对多映射8.双向多对多映射Spri...
    99+
    2022-11-12
  • SpringDataJPA实体类关系映射配置方式有哪些
    这篇文章将为大家详细讲解有关SpringDataJPA实体类关系映射配置方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。SpringDataJPA//FetchType.LAZY:懒加载,加载一个...
    99+
    2023-06-21
  • JPA配置方式+逆向工程映射到Entity实体类
    目录将已有项目转换成JPAproject..此时会显示警告准备:wildfly/tomcat或者其他服务器 你的数据库的Driver,(此处用的mysql-connecter-jav...
    99+
    2022-11-12
  • JPA配置方式+逆向工程映射到Entity实体类的示例分析
    这篇文章主要为大家展示了“JPA配置方式+逆向工程映射到Entity实体类的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JPA配置方式+逆向工程映射到Entity实体类的示例分析”这篇...
    99+
    2023-06-25
  • Mybatis全局配置及映射关系的实现
    目录一、配置文件内容1.1、Proerties1.2、设置setting1.3、类型别名typeAliases1.4、映射器Mappers1.5、dataSource1.6、事务二、...
    99+
    2022-11-13
  • mybatisPlus实体类与数据库表映射关系详解
    目录实体类与数据库表映射关系具体的映射方法有两种忽略某个实体类属性和数据库表字段之间的映射关系问题描述解决方案实体类与数据库表映射关系 使用mybatisPlus时,会确定实体类和数...
    99+
    2022-11-12
  • Mybatis全局配置及映射关系怎么实现
    这篇文章主要介绍了Mybatis全局配置及映射关系怎么实现,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、配置文件内容mybatis.xml就是Mybatis的全局配置文件...
    99+
    2023-06-29
  • mybatis Plus实体类与数据库表映射关系是什么
    这篇“mybatis Plus实体类与数据库表映射关系是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mybatis P...
    99+
    2023-06-26
  • mybatis plus实体类中字段映射mysql中的json格式方式
    目录mybatis plus实体类中字段映射mysql中的json格式1.实体类中有个属性是其他对象2.那么取出时怎么进行映射呢,有分为两种情况mybatis-plus 实体 jso...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作