百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

详细介绍一下Spring Boot3中如何整合JPA技术?

ccwgpt 2025-04-09 14:35 23 浏览 0 评论

JPA(Java Persistence API)技术是JavaEE中用来定义标准接口和规范的技术,主要的目的就是为了简化数据库的操作。属于一种ORM (Object-Relational Mapping) 规范,这个规范就允许开发者将Java对象映射到关系型数据库中的关系型数据表中,它并不是某个具体的技术体现,而是一种技术规范的体现。具体的使用技术有Hibernate、EclipseLink、OpenJPA 等,下面我们就来介绍下如何在Spring Boot3中整合JPA技术。

引入依赖配置

结合Spring Boot框架的使用,想要使用JPA技术就必须要引入JPA的相关依赖配置。如下所示。


    
    
        org.springframework.boot
        spring-boot-starter-web
    

    
    
        org.springframework.boot
        spring-boot-starter-data-jpa
    

    
    
        com.h2database
        h2
        runtime
    

    
    
        org.springframework.boot
        spring-boot-starter-test
        test
    

    
    

从依赖配置中可以看到引入了spring-boot-starter-data-jpa依赖配置,也就是说引入的实Spring Boot JPA的依赖配置,Spring Boot JPA是对JPA进行了封装,提供了大量对JPA技术的扩展,尤其是在CRUD操作方面,在后面我们会提到。

添加配置

依赖添加完成之后,接下来就是根据配置依赖,添加对应的数据库连接配置、JPA映射配置等配置内容。这里我们演示通过H2数据库来进行连接配置,如下所示。

# 数据源配置
spring:
  datasource:
    url: jdbc:h2:mem:testdb  # H2内存数据库的连接URL(根据实际使用的数据库修改)
    driver-class-name: org.h2.Driver
    username: sa
    password: password
    hikari:
      maximum-pool-size: 10  # 设置连接池大小(可根据需要调整)

  # JPA配置
  jpa:
    hibernate:
      ddl-auto: update  # 创建或更新数据库表结构(可以根据需要设置为 none、validate、update 或 create)
    database-platform: org.hibernate.dialect.H2Dialect  # H2数据库的方言(根据使用的数据库修改)
    show-sql: true  # 显示SQL语句
    properties:
      hibernate:
        format_sql: true  # 格式化SQL输出

  # 启用自动配置,Spring Boot会自动配置JPA数据源、EntityManager等
  jpa:
    open-in-view: false  # 关闭Open Session in View,减少性能开销,避免懒加载异常

# 端口配置
server:
  port: 8080  # 设置应用的监听端口

# 其他常用配置
logging:
  level:
    org.springframework.web: DEBUG  # 设置Web相关日志级别
    org.hibernate.SQL: DEBUG  # 打印Hibernate执行的SQL语句

当然如果在项目中使用的是其他的数据库则可以将配置修改为如下的配置内容,如下所示,以MySQL数据库为例,这个时候需要注意,需要在POM依赖文件中添加MySQL的驱动依赖。

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/your_database?useSSL=false&serverTimezone=UTC
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: root
    hikari:
      maximum-pool-size: 10

  jpa:
    hibernate:
      ddl-auto: update
    database-platform: org.hibernate.dialect.MySQL8Dialect
    show-sql: true
    properties:
      hibernate:
        format_sql: true

具体使用

根据JPA的概念,我们首先需要先来定义一个Java的实体类对象,如下所示。

定义实体类

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;
    private String email;

    // getters and setters
}

创建JPA仓库

Spring Boot JPA中提供了对于数据访问的封装,我们可以继承JpaRepositoryCrudRepository接口来实现自定义的数据库访问方法,当然在默认实现中也提供了一些直接可以使用的方法,如save(), findById(), findAll()等,如下所示。

package com.example.demo.repository;

import com.example.demo.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository {
    // 可以定义自定义查询方法
    User findByEmail(String email);
}

创建服务层

服务层通常会依赖于Repository来进行数据的CRUD操作,我们可以在服务层中对相关的业务逻辑进行封装。

@Service
public class UserService {

    private final UserRepository userRepository;

    public UserService(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    // 查询所有用户
    public List getAllUsers() {
        return userRepository.findAll();
    }

    // 根据id查询用户
    public Optional getUserById(Long id) {
        return userRepository.findById(id);
    }

    // 根据邮箱查询用户
    public User getUserByEmail(String email) {
        return userRepository.findByEmail(email);
    }

    // 创建用户
    public User createUser(User user) {
        return userRepository.save(user);
    }
}

创建控制器

最后就是通过Controller层的控制器类来暴露RESTFulAPI接口,提供给前端服务或者是其他的微服务进行调用。如下所示。

@RestController
@RequestMapping("/users")
public class UserController {

    private final UserService userService;

    public UserController(UserService userService) {
        this.userService = userService;
    }

    // 获取所有用户
    @GetMapping
    public List getAllUsers() {
        return userService.getAllUsers();
    }

    // 根据ID获取用户
    @GetMapping("/{id}")
    public Optional getUserById(@PathVariable Long id) {
        return userService.getUserById(id);
    }

    // 根据邮箱获取用户
    @GetMapping("/email/{email}")
    public User getUserByEmail(@PathVariable String email) {
        return userService.getUserByEmail(email);
    }

    // 创建用户
    @PostMapping
    @ResponseStatus(HttpStatus.CREATED)
    public User createUser(@RequestBody User user) {
        return userService.createUser(user);
    }
}

这样,我们整个的JPA服务就算搭建成功了。

总结

JPA技术通过ORM映射对数据库表和Java对象之间进行了自动化的转换,减少了直接操作数据库的复杂性,结合Spring Boot技术的快速敏捷,可以提供非常高效的接口实现方案。对于常见的数据库CRUD操作,使用JPA可以大大减少手动编写SQL的工作,提高开发效率。

相关推荐

公司组织架构及部门职责#管理制度 #薪酬绩效 #组织架构

...

终于把“公司组织架构与管理部岗位配置”整理好了,拿来即用!

...

老板看完这份“公司组织架构详解”就解放了!

...

丨公司丨公司大架构整理汇总

注:本文转自团队成员原创作品,特此鸣谢(公号:法海图鉴)今日话题公司大架构整理背景介绍经过前几期话题对各种企业类型的介绍,想必大家已经有了初步认识。之后我将带着大家开启对公司的深入了解。本期...

图解物理--八年级物理下册最全知识框架导图

第七章力1力2弹力3重力第八章运动和力1牛顿第一定律2二力平衡3摩擦力第九章压强1压强2液体压强3大气压强4流体压强与流速的关系第十章浮力1浮力2阿基米德原理3物体的浮沉条件及应用第十一章功...

八年级上册生物,思维导图,期末高分必备资料,家长收藏

这是八年级上册生物的思维导图,孩子在背诵知识点的时候,可以看一下知识点在导图中的位置,形成对知识点整体的把握,有助于学生拿高分,特别是图片中带红色星星的部分,更是要注意背诵,是重点内容。家长可以把图片...

2019政府工作报告精华,这张思维导图里全都有

每经记者:李可愚每经编辑:陈星每日经济新闻

图解薪酬体系结构设计

...

司考复习独家总结!一张图总结行政法知识结构体系

作为三大实体法之一,行政法的分值在60分左右,行政法在司法考试中一直比较平稳常规,没有偏题怪题,还是比较容易得分的。小编要提醒大家,在3月之前要把三大实体法学习一遍。下图是厚大在线360导学师小周总结...

一图读懂香港国安新架构:各职位人选公布 有官员曾强硬喊话乱港分子

实用干货!高中物理框架图,让零碎知识“串联”起来

高中物理学习一定要抓好逻辑结构大框架!了解整个知识框架体系后,更易抓住骨干知识,干掉重难知识点~今天给大家分享高中物理的框架图同学们赶紧收藏起来吧!力学知识结构图光学知识结构图热学、原子物理知识结构图...

254m超高层办公楼型钢砼框架-核心筒结构图

高度类别:超高层建筑钢筋混凝土结构:框架,框架核心筒钢结构:钢框架建筑功能:办公包含:办公楼57层(-3层)254.150m钻孔灌注桩桩+筏板型钢混凝土框架-钢筋混凝土核心筒西裙房2层(-...

砖混结构与框架结构,究竟有何区别?千万别被坑!

现在买房装修的人最怕啥?不是价格高,而是房子不安全!两种主流建筑结构,砖混靠墙,框架靠柱子,选错了隔墙都可能要命。简单说,砖混便宜但别碰高层,框架贵点但能保命。砖混那些承重墙根本不能拆,想砸墙改个开放...

大师一百——高中化学必考:《元素周期律》考点框架图

今天大师给大家带来的是高中化学的《元素周期律》考点框架图,高中的同学必须牢记于心,这种重要的考点,考试是一定会考的!化学大师...

需求分析框架图

需求分析框架图

取消回复欢迎 发表评论: