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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...