背景
软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费或多或少的时间、检索不止一篇资料才能得出一个可工作的DEMO,这占用了我大量的时间精力。因此本文旨在通过一篇文章即能还原出可工作的、甚至可用于生产的DEMO,期望初学者能尽快地迈过0到1的这一步骤,并在此基础上不断深化对相关知识的理解。
为达以上目的,本文会将开发环境、工程目录结构、开发步骤及源码尽量全面地展现出来,文字描述能简则简,能用代码注释的绝不在正文中再啰嗦一遍,正文仅对必要且关键的信息做重点描述。
介绍
存储一对一关联关系可以使用 主从双数据表 或 带有中间关联关系表的三数据表,在《【Spring Boot 3】【JPA】一对一单向关联》 和 《【Spring Boot 3】【JPA】一对一双向关联》 中说明了基于 主从双数据表 的实现,本文介绍 带有中间关联关系表的三数据表 实现。
本文定义了房屋(House)、地址(Address)、房产证(Certificate)三个实体,其中房屋(House)与地址(Address)一对一单向关联,房屋(House)与房产证(Certificate)一对一双向关联,关系主控方(即关系拥有方)都是房屋(House)。
开发环境
| 分类 | 名称 | 版本 |
|---|---|---|
| 操作系统 | Windows | Windows 11 |
| JDK | Oracle JDK | 21.0.1 |
| IDE | IntelliJ IDEA | 2023.2.4 |
| 构建工具 | Apache Maven | 3.9.3 |
| 数据库 | MySQL | 8.0.33 |
开发步骤及源码
1> 创建Maven工程,添加依赖。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.jiyongliang</groupId>
<artifactId>springboot3-jpa</artifactId>
<version>0.0.1</version>
</parent>
<artifactId>springboot3-jpa-one-to-one-table</artifactId>
<properties>
<java.version>21</java.version>
<maven.compiler.source>21</maven.compiler.source>
<maven.compiler.target>21</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<spring-boot.version>3.2.2</spring-boot.version>
<mysql-connector-j.version>8.3.0</mysql-connector-j.version>
<flyway.version>10.6.0</flyway.version>
<lombok.version>1.18.30</lombok.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>${mysql-connector-j.version}</version>
<scope>runtime</scope>
</dependency>
<!-- 引入Flyway管理数据库迁移 -->
<dependency>

本文介绍了如何在Spring Boot 3应用中使用JPA实现一对一中间表关联的示例。文章详细展示了从创建Maven工程、添加依赖,到定义Entity、Repository,以及进行单元测试的全过程。涉及房屋、地址和房产证三个实体,其中房屋与地址一对一单向关联,房屋与房产证一对双向关联。同时,文章强调了中间表实体和Repository在单元测试中的作用,以及在实际业务中可能不需要的情况。最后提醒开发者对于价格字段的数据类型选择应根据实际情况调整。
最低0.47元/天 解锁文章
2万+

被折叠的 条评论
为什么被折叠?



