欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringDataJPA實體類關(guān)系映射配置方式

 更新時間:2021年12月06日 10:14:47   作者:墻角斑駁  
這篇文章主要介紹了SpringDataJPA實體類關(guān)系映射配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

SpringDataJPA

//FetchType.LAZY:懶加載,加載一個實體時,定義懶加載的屬性不會馬上從數(shù)據(jù)庫中加載
//FetchType.EAGER:急加載,加載一個實體時,定義急加載的屬性會立即從數(shù)據(jù)庫中加載
//cascade = CascadeType.ALL 表示所有情況下均進(jìn)行關(guān)聯(lián)操作,即save-update和delete
@JsonBackReference   //解決循環(huán)引用問題
@JsonIgnoreProperties(value = "order") //解決循環(huán)引用問題,order內(nèi)容大,不加載
//雙向映射存在轉(zhuǎn)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;

總結(jié)

添加時候需要先添加@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;

總結(jié)

@JsonBackReference   //解決循環(huán)引用問題
@JsonIgnoreProperties(value = "order") //解決循環(huán)引用問題,order內(nèi)容大,不加載
//雙向映射存在轉(zhuǎn)json無限遞歸問題 需要注解來處理 推薦使用第二個注解 value值為對方表作映射的變量值

3.單向一對多映射

一方

    @Id
    @GeneratedValue
    private Long id;
    @Column(length = 32)
    private String name;
    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)//級聯(lián)保存、更新、刪除、刷新;延遲加載
    @JoinColumn(name = "author_id")//在book表增加一個外鍵列來實現(xiàn)一對多的單向關(guān)聯(lián)
    private Set<Book> books = new HashSet<Book>();

多方

    //單向一對多的情況下  多方不需要加任何關(guān)聯(lián)標(biāo)識
 @Id
    @GeneratedValue
    private Long id;
    @Column(length=32)
    private String name;

總結(jié)

因為是單向的關(guān)聯(lián),多方不需要加任何的關(guān)聯(lián)標(biāo)識 只需要在一方添加即可

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; //收貨地址
    // 訂單與客戶關(guān)聯(lián)
    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "c_id") //指定外鍵列  
    @JsonIgnoreProperties(value = "order") //解決循環(huán)引用問題,order內(nèi)容大,不加載
    private Customer customer; //描述訂單屬于某一個客戶

總結(jié)

@JsonBackReference   //解決循環(huán)引用問題
@JsonIgnoreProperties(value = "order") //解決循環(huán)引用問題,order內(nèi)容大,不加載
//雙向映射存在轉(zhuǎn)json無限遞歸問題 需要注解來處理 推薦使用第二個注解 value值為對方表作映射的變量值

5.單向多對一映射

多方

 @GeneratedValue
 @Id
 private Integer id;
 @Column(name="ORDER_NAME")
 private String orderName;
 //映射單向 n-1的關(guān)聯(lián)關(guān)系
 //使用@ManyToOne來映射多對一的關(guān)聯(lián)關(guān)系
 //使用@JoinColumn 來映射外鍵
 //可使用 @ManyToOne 的fetch 屬性來修改默認(rèn)的關(guān)聯(lián)屬性的加載策略
 @JoinColumn(name="CUSTOMER_ID")  //此外鍵為一方的主鍵
 @ManyToOne(fetch=FetchType.EAGER)
 private Customer customer;

一方

    //單向多對一的情況下,一方不需要加任何關(guān)聯(lián)標(biāo)識
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Id
    private Integer id;
    private String lastName;
    private String email;
    private int age;
    private Date createdTime;
    private Date birth;

總結(jié)

保存多對一時,建議先保存1的一端,后保存n的一端,這樣不會多出額外的update語句。

6.雙向多對一映射

多方

 @GeneratedValue
 @Id
 private Integer id;
 @Column(name="ORDER_NAME")
 private String orderName;
 //映射單向 n-1的關(guān)聯(lián)關(guān)系
 //使用@ManyToOne來映射多對一的關(guān)聯(lián)關(guān)系
 //使用@JoinColumn 來映射外鍵
 //可使用 @ManyToOne 的fetch 屬性來修改默認(rèn)的關(guān)聯(lián)屬性的加載策略
 @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的關(guān)聯(lián)關(guān)系
    //使用@OneToMany 映射單向1-n的關(guān)聯(lián)關(guān)系
    //使用@JoinColumn 來映射外鍵的名稱
    //可以使用@OneToMany 的 fetch 屬性來修改加載策略
    //可以使用@OneToMany 的 cascade 屬性來修改默認(rèn)的刪除策略
//    @JoinColumn(name="CUSTOMER_ID")
    //一的一端放棄維持關(guān)聯(lián)關(guān)系
    @OneToMany(fetch=FetchType.EAGER,cascade={CascadeType.REMOVE},mappedBy="customer")
    @JsonIgnoreProperties(value = "orders")
    private Set<Order> orders = new HashSet<>();

總結(jié)

1.必須使用@JsonIgnoreProperties注解來攔截轉(zhuǎn)json時無限遞歸的問題

2.若是雙向 1-n 的關(guān)聯(lián)關(guān)系, 執(zhí)行保存時:

(1)若先保存 n 的一端, 再保存 1 的一端, 默認(rèn)情況下, 會多出2n 條 UPDATE 語句;

(2)若先保存 1 的一端, 則會多出 n 條 UPDATE 語句。

(3)故在進(jìn)行雙向 1-n 關(guān)聯(lián)關(guān)系時, 建議使用 n 的一方來維護(hù)關(guān)聯(lián)關(guān)系, 而 1 的一方不維護(hù)關(guān)聯(lián)系, 這樣會有效的減少 SQL 語句(即,N的一端對應(yīng)的表中使用外鍵關(guān)聯(lián)1的一端,外鍵對應(yīng)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")},
            //反轉(zhuǎn)  user這個表的 反面則是 role
            inverseJoinColumns = {@JoinColumn(name = "role_id")})
    private Set<Role> roles = new HashSet<>();

多方

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

總結(jié)

使用 @JoinTable 來映射中間表

1. name 指向中間表的名字

2. joinColumns 映射當(dāng)前類所在的表在中間表中的外鍵

2.1 name 指定外鍵列的列名

2.2 referencedColumnName 指定外鍵列關(guān)聯(lián)當(dāng)前表的哪一列

3. inverseJoinColumns 映射關(guān)聯(lián)的類所在中間表的外鍵

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<>();

總結(jié)

使用 @JoinTable 來映射中間表

1. name 指向中間表的名字

2. joinColumns 映射當(dāng)前類所在的表在中間表中的外鍵

2.1 name 指定外鍵列的列名

2.2 referencedColumnName 指定外鍵列關(guān)聯(lián)當(dāng)前表的哪一列

3. inverseJoinColumns 映射關(guān)聯(lián)的類所在中間表的外鍵

@JsonBackReference //解決循環(huán)引用問題
@JsonIgnoreProperties(value = "order") //解決循環(huán)引用問題,order內(nèi)容大,不加載

雙向映射存在轉(zhuǎn)json無限遞歸問題 需要注解來處理 推薦使用第二個注解 value值為對方表作映射的變量值

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JVM垃圾回收機(jī)制和垃圾回收器詳細(xì)解說

    JVM垃圾回收機(jī)制和垃圾回收器詳細(xì)解說

    這篇文章主要介紹了JVM垃圾回收機(jī)制和垃圾回收器,為了讓程序員更加專注于代碼的實現(xiàn),而不用過多的考慮內(nèi)存釋放的問題,所以在Java語言中,有了自動的垃圾回收機(jī)制,也是我們常常提及的GC,需要的朋友可以參考下
    2022-07-07
  • Javaweb實現(xiàn)上傳下載文件的多種方法

    Javaweb實現(xiàn)上傳下載文件的多種方法

    本篇文章主要介紹了Javaweb實現(xiàn)上傳下載文件,有多種實現(xiàn)方式,需要的朋友可以參考下。
    2016-10-10
  • Java編程幾個循環(huán)實例代碼分享

    Java編程幾個循環(huán)實例代碼分享

    這篇文章主要介紹了Java編程幾個循環(huán)實例代碼分享,多看多練,小編覺得還是挺不錯的,這里分享給大家,供需要的朋友參考。
    2017-10-10
  • 深度解析SpringBoot中@Async引起的循環(huán)依賴

    深度解析SpringBoot中@Async引起的循環(huán)依賴

    本文主要介紹了深度解析SpringBoot中@Async引起的循環(huán)依賴,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • SpringBoot實現(xiàn)自定義指標(biāo)監(jiān)控功能

    SpringBoot實現(xiàn)自定義指標(biāo)監(jiān)控功能

    本文主要介紹了SpringBoot實現(xiàn)自定義指標(biāo)監(jiān)控功能的實現(xiàn),,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,感興趣的小伙伴跟著著小編來一起來學(xué)習(xí)吧
    2024-01-01
  • 關(guān)于@MapperScan和@ComponentScan的使用問題

    關(guān)于@MapperScan和@ComponentScan的使用問題

    文章介紹了在使用`@MapperScan`和`@ComponentScan`時可能會遇到的包掃描沖突問題,并提供了解決方法,同時,還詳細(xì)解釋了`@MapperScan`和`@ComponentScan`的功能和使用場景
    2025-01-01
  • idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    這篇文章主要介紹了idea 自動生成類注釋和方法注釋的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Java?深入理解創(chuàng)建型設(shè)計模式之抽象工廠模式

    Java?深入理解創(chuàng)建型設(shè)計模式之抽象工廠模式

    當(dāng)系統(tǒng)所提供的工廠所需生產(chǎn)的具體產(chǎn)品并不是一個簡單的對象,而是多個位于不同產(chǎn)品等級結(jié)構(gòu)中屬于不同類型的具體產(chǎn)品時需要使用抽象工廠模式,抽象工廠模式是所有形式的工廠模式中最為抽象和最具一般性的一種形態(tài)
    2022-02-02
  • mybatisplus 多表關(guān)聯(lián)條件分頁查詢的實現(xiàn)

    mybatisplus 多表關(guān)聯(lián)條件分頁查詢的實現(xiàn)

    本文主要介紹了mybatisplus 多表關(guān)聯(lián)條件分頁查詢的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-01-01
  • 關(guān)于junit單元測試@Test的使用方式

    關(guān)于junit單元測試@Test的使用方式

    這篇文章主要介紹了關(guān)于junit單元測試@Test的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07

最新評論