JPA中實現雙向一對一的關聯關係

来源:https://www.cnblogs.com/badaoliumangqizhi/archive/2019/12/13/12036144.html
-Advertisement-
Play Games

場景 JPA入門簡介與搭建HelloWorld(附代碼下載): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103473937 JPA中實現單向多對一的關聯關係: https://blog.csdn.net/BADAO_LIUM ...


場景

JPA入門簡介與搭建HelloWorld(附代碼下載):

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103473937

JPA中實現單向多對一的關聯關係:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103511623

JPA中實現單向一對多的關聯關係:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103520083

JPA中實現雙向一對多的關聯關係:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103523564

按照上面的流程實現以上映射關係後,怎樣在JPA中實現雙向一對一的映射關係。

比如部門與經理就是雙向一對一的關係。

註:

博客主頁:
https://blog.csdn.net/badao_liumang_qizhi
關註公眾號
霸道的程式猿
獲取編程相關電子書、教程推送與免費下載。

實現

為了構造出雙向一對一的關聯關係,新增經理和部門兩個資料庫表和實體類。

新建資料庫表JPA_MANAGERS經理表

 

 

設計部門表JPA_DEPARTMENTS

 

 

然後新建部門實體類Department

package com.badao.jpa.helloworld;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import javax.persistence.Table;

@Table(name="JPA_DEPARTMENTS")
@Entity
public class Department {

 private Integer id;
 private String deptName;
 
 private Manager mgr;

 @GeneratedValue(strategy = GenerationType.IDENTITY)
 @Id
 public Integer getId() {
  return id;
 }

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

 @Column(name="DEPT_NAME")
 public String getDeptName() {
  return deptName;
 }

 public void setDeptName(String deptName) {
  this.deptName = deptName;
 }

 //使用 @OneToOne 來映射 1-1 關聯關係。
 //若需要在當前數據表中添加主鍵則需要使用 @JoinColumn 來進行映射. 註意, 1-1 關聯關係, 所以需要添加 unique=true
 @JoinColumn(name="MGR_ID", unique=true)
 @OneToOne(fetch=FetchType.LAZY)
 public Manager getMgr() {
  return mgr;
 }

 public void setMgr(Manager mgr) {
  this.mgr = mgr;
 }
}

 

註:

1.使用 @OneToOne 來映射 1-1 關聯關係。

2.若需要在當前數據表中添加主鍵則需要使用 @JoinColumn 來進行映射. 註意, 1-1 關聯關係, 所以需要添加 unique=true。

3.這裡是雙向的一對一映射,所以要選擇一方作為維護主要關聯關係的一方添加@JoinColumn(name="MGR_ID", unique=true)

然後再新建經理實體類

package com.badao.jpa.helloworld;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;
import javax.persistence.Table;

@Table(name="JPA_MANAGERS")
@Entity
public class Manager {

 private Integer id;
 private String mgrName;
 
 private Department dept;

 @GeneratedValue(strategy = GenerationType.IDENTITY)
 @Id
 public Integer getId() {
  return id;
 }

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

 @Column(name="MGR_NAME")
 public String getMgrName() {
  return mgrName;
 }

 public void setMgrName(String mgrName) {
  this.mgrName = mgrName;
 }

 //對於不維護關聯關係, 沒有外鍵的一方, 使用 @OneToOne 來進行映射, 建議設置 mappedBy=另一方外鍵
 @OneToOne(mappedBy="mgr")
 public Department getDept() {
  return dept;
 }

 public void setDept(Department dept) {
  this.dept = dept;
 }
}

 

註:

1.對於不維護關聯關係, 沒有外鍵的一方, 使用 @OneToOne 來進行映射, 建議設置 mappedBy=另一方外鍵。

2.因為此方不維護關聯關係,所以直接使用@OneToOne的mappedBy屬性,屬性值對應的是另一方的外鍵屬性名。

然後在配置文件persistence.xml中添加實體類的配置

<class>com.badao.jpa.helloworld.Manager</class>
<class>com.badao.jpa.helloworld.Department</class>

 

添加位置如下

 

 

然後編寫單元測試方法

  

@Test
  public void testOneToOnePersistence(){
   Manager mgr = new Manager();
   mgr.setMgrName("M-BB");
   
   Department dept = new Department();
   dept.setDeptName("D-BB");
   
   //設置關聯關係
   mgr.setDept(dept);
   dept.setMgr(mgr);
   
   //執行保存操作
   entityManager.persist(mgr);
   entityManager.persist(dept);
  }

 

註:

雙向 1-1 的關聯關係, 建議先保存不維護關聯關係的一方, 即沒有外鍵的一方, 這樣不會多出 UPDATE 語句。

運行單元測試方法後查看資料庫表

經理表

 

 

部門表

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 昨天有使用soap傳輸數據到Webservice,其中字元串類型的都已經傳輸成功,但是有幾個參數傳輸失敗,java伺服器端收到的空值。 因為我是php的,然後接收端是java製作的,其中有幾個參數是list數組類型的,我剛開始將php的數組傳過去,服務端接收到的是空,然後再使用json格式還是不行。 ...
  • 第一次寫博客,本文主要源於圖像處理大作業,不足之處,還望指正。 1. Introduction (5%) The task of the project is to find the dial-code switch in the figure below and calibrate the rec ...
  • 公司兩個系統。 我們的A系統要給B系統上送業務簽約單申請。B系統接收數據後,非同步處理,簽約完成會主動發送通知給我們的A系統。 介面文檔里說明瞭,通過http協議的post請求來發送非同步通知,報文是json格式字元串。But,But,But, ...
  • 之前我們使用VSCode搭建C 項目,今天寫一篇關於django項目的搭建;django官網:https://www.djangoproject.com/ 安裝django django安裝命令: ,參考:https://docs.djangoproject.com/en/3.0/topics/in ...
  • spring 第一章 Spring模塊規劃圖 核心架包 AOP+Aspects(面向切麵編程模塊) 數據訪問/:Spring資料庫訪問模塊 Web:Spring開發web應用的模塊; ecplise插件的安裝 1.ecplise查看版本號: Help About Eclipse 點擊自己eclips ...
  • 二、Celery基本使用 1.創建一個celery application 用來定義你的任務列表,創建一個任務文件就叫tasks.py吧。 from celery import Celery # 配置好celery的backend和broker app = Celery('task1', backe ...
  • 一、下載(原文鏈接:http://www.studyshare.cn/software/details/1183/0 ) 1、官網下載:下載地址 2、百度網盤下載:下載地址 提取碼:0g5a java開發工具下載地址及安裝教程大全,點這裡。 更多深度技術文章,在這裡。 二、安裝及啟動 1、前提條件: ...
  • 本文將介紹在Java程式中如何將Excel工作簿轉為PDF文檔的,包括: 將整個工作簿轉為PDF 將指定工作表轉為PDF 使用工具:Free Spire.XLS for Java (免費版) Jar文件下載及導入: 方法1:通過官網下載。下載後,解壓文件,將lib文件夾下的Spire.Xls.jar ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...