溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

spring jpa中ManyToMany的原理是什么

發(fā)布時(shí)間:2021-05-12 16:52:32 來(lái)源:億速云 閱讀:300 作者:Leah 欄目:編程語(yǔ)言

本篇文章為大家展示了spring jpa中ManyToMany的原理是什么,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

1.java和jpa 中所有的關(guān)系都是單向的。這個(gè)關(guān)系數(shù)據(jù)庫(kù)不同,關(guān)系數(shù)據(jù)庫(kù),通過(guò)外鍵定義并查詢(xún),使得反向查詢(xún)總是存在的。

2.JPA還定義了一個(gè)OneToMany關(guān)系,它與ManyToMany關(guān)系類(lèi)似,但反向關(guān)系(如果已定義)是ManyToOne關(guān)系。

OneToMany與JPA中ManyToMany關(guān)系的主要區(qū)別在于,ManyToMany總是使用中間關(guān)系連接表來(lái)存儲(chǔ)關(guān)系,

OneToMany可以使用連接表或者目標(biāo)對(duì)象的表引用中的外鍵源對(duì)象表的主鍵。

@OneToMany(cascade = CascadeType.ALL)
  @JoinColumn(name = "OPR_WARE_SYSCONFIG_ID",foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT))
  private List<WarehouseVO> warehouse;

wareHouseVO的表通過(guò)外鍵字段關(guān)聯(lián),而定義了OneToMany的屬性的VO則不需要添加表字段。

spring jpa中ManyToMany的原理是什么

spring jpa中ManyToMany的原理是什么

ManyToOne:

@ManyToOne
  @JoinColumn(name = "OPR_WAREHOUSE_ENV_ID")
  private EnvironmentVO env ;

spring jpa中ManyToMany的原理是什么

spring jpa中ManyToMany的原理是什么

總結(jié),作為many的一方需要有外鍵關(guān)聯(lián)One的一方。

@ManyToMany 注解

manyToMany需要和@JoinTable表結(jié)合使用,ManyToMany總是使用中間關(guān)系連接表來(lái)存儲(chǔ)關(guān)系。如果兩個(gè)Vo都定義了ManyToMany的話,因?yàn)閱蜗蜿P(guān)系,會(huì)生成有2個(gè)中間表。所以需要改造成雙向關(guān)系,使其只存在一個(gè)中間表。

例子:

a:一方不需要mappedBy屬性,一方需要。

@ManyToMany
  @JoinTable(name = "AUTO_SYSTEM", joinColumns = { @JoinColumn(name = "OPR_AUTO_ID") }, inverseJoinColumns = {
      @JoinColumn(name = "OPR_SYSTEM_ID") }, foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT), inverseForeignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT))
  private List<SystemVO> systems;
@ManyToMany(mappedBy = "students")
private List<Service> services;

b:

@Entity
public class Student {
  @Id
  private String id;
  @ManyToMany
  @JoinTable
  private List<Teacher> teachers;
}
 
@Entity
public class Teacher {
  @Id
  private String id;
  @ManyToMany
  @JoinTable
  private List<Student> students;
}

@ManyToMany即表示了老師和學(xué)生的多對(duì)多關(guān)系。@ManyToMany注解可以用在字段或方法上

但是這樣會(huì)有兩個(gè)表出現(xiàn),TEACHER_STUDENTS表和STUDENT_TEACHERS。

原因是這里的多對(duì)多關(guān)系正是維基百科提到的單向原則。老師和學(xué)生雖然分別定義了自己的多對(duì)多關(guān)系,但這個(gè)關(guān)系都是單向的,要使關(guān)系成為雙向。

mappedBy 屬性

mappedBy是OneToOne、OneToMany和ManyToMany這三種關(guān)聯(lián)關(guān)系的屬性。

用來(lái)標(biāo)注擁有這種關(guān)系的字段。 除非關(guān)系是單向的,否則是必需的。

什么叫擁有關(guān)聯(lián)關(guān)系呢,假設(shè)是雙向一對(duì)一的話,那么擁有關(guān)系的這一方有建立、解除和更新與另一方關(guān)系的能力。而另一方?jīng)]有,只能被動(dòng)管理。

由于JoinTable和JoinColumn一般定義在擁有關(guān)系的這一端,而mappedBy一定是定義在關(guān)系的被擁有方(the owned side),也就是跟定義JoinTable

和JoinColumn互斥的一方,它的值指向擁有方中關(guān)于被擁有方的字段,可能是一個(gè)對(duì)象(OneToMany),也可能是一個(gè)對(duì)象集合(ManyToMany)。

@Entity
public class Student {
  @Id
  private String id;
  @ManyToMany(mappedBy = "students")
  private List<Teacher> teachers;
}
 
@Entity
public class Teacher {
  @Id
  private String id;
  @ManyToMany
  @JoinTable(“student”)
  private List<Student> students;
}

這時(shí)中間表只有一張TEACHER_STUDENTS,關(guān)聯(lián)關(guān)系也變成了我們想要的雙向關(guān)系。

Cascade 級(jí)聯(lián)關(guān)系

實(shí)際業(yè)務(wù)中,我們通常會(huì)遇到以下情況:

1.用戶(hù)和用戶(hù)的收貨地址是一對(duì)多關(guān)系,當(dāng)用戶(hù)被刪除時(shí),這個(gè)用戶(hù)的所有收貨地址也應(yīng)該一并刪除。

2.訂單和訂單中的商品也是一對(duì)多關(guān)系,但訂單被刪除時(shí),訂單所關(guān)聯(lián)的商品肯定不能被刪除。

此時(shí)只要配置正確的級(jí)聯(lián)關(guān)系,就能達(dá)到想要的效果。

級(jí)聯(lián)關(guān)系類(lèi)型:

  • CascadeType.REFRESH:級(jí)聯(lián)刷新,當(dāng)多個(gè)用戶(hù)同時(shí)作操作一個(gè)實(shí)體,為了用戶(hù)取到的數(shù)據(jù)是實(shí)時(shí)的,在用實(shí)體中的數(shù)據(jù)之前就可以調(diào)用一下refresh()方法

  • CascadeType.REMOVE:級(jí)聯(lián)刪除,當(dāng)調(diào)用remove()方法刪除Order實(shí)體時(shí)會(huì)先級(jí)聯(lián)刪除OrderItem的相關(guān)數(shù)據(jù)

  • CascadeType.MERGE:級(jí)聯(lián)更新,當(dāng)調(diào)用了Merge()方法,如果Order中的數(shù)據(jù)改變了會(huì)相應(yīng)的更新OrderItem中的數(shù)據(jù)

  • CascadeType.ALL:包含以上所有級(jí)聯(lián)屬性

  • CascadeType.PERSIST:級(jí)聯(lián)保存,當(dāng)調(diào)用了Persist() 方法,會(huì)級(jí)聯(lián)保存相應(yīng)的數(shù)據(jù)

上述內(nèi)容就是spring jpa中ManyToMany的原理是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI