【Spring Boot 入门三】Spring Boot与数据库集成 - 构建数据驱动的应用

news2024/12/23 4:27:27

在这里插入图片描述

一、引言

在之前的文章中,我们已经对Spring Boot有了初步的认识,了解了如何构建第一个Spring Boot应用,以及如何通过配置文件来掌控应用的设置。这些知识为我们进一步探索Spring Boot与数据库的集成奠定了坚实的基础。

数据库是现代应用的核心组成部分,无论是企业级的信息管理系统、电子商务平台,还是移动应用的后端服务,都离不开数据库来存储和管理数据。Spring Boot作为一个流行的Java开发框架,提供了便捷的方式来集成各种数据库,使得开发者能够快速地构建数据驱动的应用。它简化了数据库连接、数据持久化、事务管理等复杂的操作,让开发者可以将更多的精力放在业务逻辑的实现上。

二、选择数据库和相关依赖

1. 常见数据库类型(MySQL、PostgreSQL、Oracle等)在Spring Boot中的应用

  • 比较不同数据库的特点和适用场景
    MySQL是一种开源的关系型数据库,具有广泛的应用。它以其易用性、高性能和可扩展性而受到开发者的喜爱,适用于各种规模的应用,特别是Web应用。MySQL的安装和配置相对简单,并且有丰富的文档和社区支持。

PostgreSQL是另一种强大的开源关系型数据库,它以其对复杂数据类型和高级查询功能的支持而闻名。PostgreSQL适合处理需要高度数据完整性和复杂查询的应用,如地理信息系统(GIS)、数据分析等领域。

Oracle是一款商业数据库,具有卓越的性能、可靠性和安全性。它在企业级应用中广泛使用,特别是对于大型企业和对数据安全要求极高的应用场景。然而,Oracle的使用成本相对较高,并且其管理和维护也较为复杂。

2. 在Spring Boot项目中添加数据库依赖

  • 使用Maven或Gradle添加依赖
    在Spring Boot项目中,如果使用Maven作为构建工具,以MySQL为例,需要在项目的pom.xml文件中添加以下依赖:
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql - connector - java</artifactId>
</dependency>

如果使用Gradle作为构建工具,则需要在build.gradle文件中添加类似的依赖:

dependencies {
    implementation 'mysql:mysql - connector - java'
}

三、数据库连接配置

1. 在配置文件中配置数据库连接参数

  • 用户名、密码、数据库URL等的设置
    application.propertiesapplication.yml文件中配置MySQL数据库连接参数。例如,在application.properties文件中:
spring.datasource.url = jdbc:mysql://localhost:3306/mydb?useSSL = false&serverTimezone = UTC
spring.datasource.username = root
spring.datasource.password = password

application.yml文件中:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydb?useSSL = false&serverTimezone = UTC
    username: root
    password: password
  • 不同数据库连接参数的差异
    不同的数据库有不同的连接参数格式。例如,Oracle数据库的连接URL可能是jdbc:oracle:thin:@localhost:1521:orcl,并且其用户名和密码的设置方式可能与MySQL有所不同。

2. 使用数据源(DataSource)

  • 讲解Spring Boot默认的数据源配置
    Spring Boot默认使用HikariCP作为数据源,它是一个高性能的数据源实现。Spring Boot会根据在配置文件中设置的连接参数自动配置数据源。

  • 如何自定义数据源(如使用Druid数据源)
    要使用Druid数据源,首先需要添加Druid的依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid - spring - boot - starter</artifactId>
    <version>1.2.6</version>
</dependency>

然后在配置文件中进行Druid数据源的配置:

spring.datasource.druid.url = jdbc:mysql://localhost:3306/mydb?useSSL = false&serverTimezone = UTC
spring.datasource.druid.username = root
spring.datasource.druid.password = password
spring.datasource.druid.initial - size = 5
spring.datasource.druid.min - idle = 5
spring.datasource.druid.max - active = 20

四、使用JPA(Java Persistence API)进行数据持久化

1. 介绍JPA在Spring Boot中的应用

  • JPA的概念和优势
    JPA是Java EE中的一个规范,它定义了一种对象关系映射(ORM)的标准方式。在Spring Boot中使用JPA可以让开发者使用Java对象来操作数据库,而不需要编写大量的SQL语句。JPA的优势在于提高了开发效率、代码的可维护性和可移植性。

2. 创建实体类

  • 使用@Entity注解标识实体类
    例如,创建一个简单的User实体类:
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    // 省略构造函数、getter和setter方法
}
  • 定义实体类的属性和关系(如@OneToMany@ManyToOne等关系注解)
    假设User实体类与Order实体类存在一对多的关系,可以这样定义:
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import java.util.List;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    @OneToMany(mappedBy = "user")
    private List<Order> orders;

    // 省略构造函数、getter和setter方法
}

3. 编写数据访问层(Repository)

  • 使用@Repository注解创建Repository接口
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
}
  • 继承JpaRepository,利用其提供的方法
    JpaRepository提供了许多常用的数据库操作方法,如findByIdsavedeleteById等。例如,可以这样使用findById方法:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    public User findUserById(Long id) {
        return userRepository.findById(id).orElse(null);
    }
}
  • 自定义查询方法(使用@Query注解)
    如果需要自定义查询方法,可以使用@Query注解。例如:
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
    @Query("SELECT u FROM User u WHERE u.email =?1")
    User findByEmail(String email);
}

五、数据库事务管理

1. 事务的概念和重要性

  • 在数据库操作中的作用
    事务是一组数据库操作,这些操作要么全部成功执行,要么全部失败回滚。在数据库操作中,事务用于确保数据的一致性和完整性。例如,在一个银行转账系统中,从一个账户扣款和向另一个账户存款这两个操作必须作为一个事务来处理,以确保转账过程中不会出现数据不一致的情况。

2. 在Spring Boot中管理事务

  • 使用@Transactional注解
    在Spring Boot中,可以使用@Transactional注解来标记需要事务管理的方法。例如:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    @Transactional
    public void transferMoney(Long fromUserId, Long toUserId, double amount) {
        User fromUser = userRepository.findById(fromUserId).orElse(null);
        User toUser = userRepository.findById(toUserId).orElse(null);

        fromUser.setBalance(fromUser.getBalance() - amount);
        toUser.setBalance(toUser.getBalance() + amount);

        userRepository.save(fromUser);
        userRepository.save(toUser);
    }
}
  • 事务的传播行为和隔离级别
    事务的传播行为定义了事务方法在被其他事务方法调用时的行为。例如,REQUIRED传播行为表示如果当前存在事务,则加入该事务;如果不存在事务,则创建一个新事务。

事务的隔离级别用于控制多个事务并发访问数据库时的隔离程度。常见的隔离级别有READ_UNCOMMITTEDREAD_COMMITTEDREPEATABLE_READSERIALIZABLE。不同的隔离级别在数据一致性和并发性能方面有不同的权衡。

六、总结与展望

在本文中,我们深入探讨了Spring Boot与数据库的集成。我们了解了如何选择适合的数据库并添加相关依赖,如何配置数据库连接参数和使用数据源,如何使用JPA进行数据持久化,以及如何进行数据库事务管理。这些知识是构建数据驱动的Spring Boot应用的关键。

在下一篇文章中,我们将深入探讨Spring Boot中的安全机制,包括如何使用Spring Security来保护应用的安全,如身份验证、授权、保护Web资源等方面的内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2182341.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QSqlDatabase在多线程中的使用

Qt中多线程使用数据库_qt数据库管理类支持多数据库,多线程-CSDN博客 1. 代码&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPushButton> #include <QSqlDatabase> #include <QSqlQuery> #include <QSqlError>…

【原创】基于websocket的实时文本转语音功能

功能实现&#xff0c;将长文本分段实时转成音频流&#xff0c;达到边转换边播放的效果&#xff0c;减少等待效果&#xff0c;像豆包通义千问chatgpt差不多也是这样实现的&#xff0c; 下面的效果展示 20240930_084035_哔哩哔哩_bilibili【原创】基于websocket的实时文本转语音…

Java 每日一刊(第18期):集合

文章目录 前言1. Java 集合框架概述1.1 Java 集合框架的定义和意义1.2 Java 集合框架的历史演进1.3 集合框架的基本组成部分1.4 Java 集合的优势1.5 Java 集合与数组的区别与关系 2. Java 集合框架的核心接口2.1 Collection 接口2.2 List 接口2.3 Set 接口2.4 Queue 接口2.5 Ma…

无人机在科研与教育领域的应用!

一、无人机在科研领域的应用 地理测绘与遥感&#xff1a; 无人机可以搭载相机或激光雷达等传感器&#xff0c;进行高分辨率的航拍&#xff0c;用于制作数字地形模型、生态环境监测、土地利用规划等。 在地理信息获取、地质勘察等领域&#xff0c;无人机能够高效地完成测量任…

Java中正则表达式(完整详解,附有案例+代码)

文章目录 三十三.正则表达式33.1 概述33.2 Test 三十三.正则表达式 33.1 概述 字符类 [abc]a、b 或 c&#xff08;简单类&#xff09;[^abc]任何字符&#xff0c;除了 a、b 或 c&#xff08;否定&#xff09;[a-zA-Z]a 到 z 或 A 到 Z&#xff0c;两头的字母包括在内&#x…

MQTT--EMQX入门+MQTTX使用

目录 1、什么是EMQX&#xff1f;1.1 EMQX介绍1.2 EMQX特点1.3 与物联网之间的关系以及主要的产品主要的产品 2、安装启动2.1 基本命令2.2 目录结构 3、MQTTX客户端3.1 连接配置 总结PS: 1、什么是EMQX&#xff1f; 首先你得有MQTT的知识&#xff0c;不认识MQTT的小伙伴可以先看…

JMeter对jdbc request以及foreach和loop controller的使用

Jmeter中jdbc request和foreach控制器 1. 使用variable name实现对数据库查询结果的遍历 在foreach controller中&#xff0c;注意要做variable name的关联(correlation), 否则没法取回这里的jdbc request返回的结果。这里的input variable prefix一定要和jdbc request中的var…

十七、触发器

文章目录 0. 引入1. 触发器概述2. 触发器的创建2.1 触发器的创建2.2 代码举例 3. 查看、删除触发器3.1 查看触发器3.2 删除触发器 4. 触发器的优缺点4.1 优点4.2 缺点4.3 注意点 0. 引入 在实际开发中&#xff0c;我们经常会遇到这样的情况&#xff1a;有 2 个或者多个相互关联…

《蓝桥杯算法入门》(C/C++、Java、Python三个版本)24年10月出版

推荐&#xff1a;《算法竞赛》&#xff0c;算法竞赛大全书&#xff0c;网购&#xff1a;京东 天猫  当当 文章目录 《蓝桥杯算法入门》内容简介本书读者对象作者简介联系与交流《蓝桥杯算法入门 C/C》版目录 《蓝桥杯算法入门 Java》版目录 《蓝桥杯算法入门 Python》版目录 …

vscode 连接服务器 不用输密码 免密登录

vscode 免密登录服务器 1. 本地端1&#xff09;生成密钥2&#xff09;vscode的config文件中添加id_rsa文件路径 2. 服务器端1&#xff09;在 authorized_keys 文件中加入密钥&#xff1a;2&#xff09;修改authorized_keys文件权限 1. 本地端 1&#xff09;生成密钥 在命令行…

【hot100-java】【二叉树的层序遍历】

二叉树 BFS 队列实现 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right)…

力扣(leetcode)每日一题 1845 座位预约管理系统| treeSet和priority Queue的区别|线段树

之前发过一篇&#xff0c;感觉还有深挖的地方&#xff0c;于是又补充一些信息 这题目虽然是middle难度题目&#xff0c;要解答出来是只要easy的时间&#xff0c;但是深挖可以有hard的难度 题解1 可以帮助复习线段树的使用&#xff0c;题解2 可以复习一下java基础知识 题解1 线…

免费送源码:Java+ssm+MySQL springboot健康医疗系统 计算机毕业设计原创定制

摘 要 随着我国经济迅速发展&#xff0c;人们对医疗管理的需求越来越大&#xff0c;各种健康医疗系统也都在被广泛应用&#xff0c;对于医疗管理的各种软件也是备受用户的喜爱&#xff0c;健康医疗系统被用户普遍使用&#xff0c;为方便用户能够可以随时进行健康医疗系统的数据…

【JAVA开源】基于Vue和SpringBoot的美容院管理系统

本文项目编号 T 055 &#xff0c;文末自助获取源码 \color{red}{T055&#xff0c;文末自助获取源码} T055&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析5.4 用例设计 六、核…

NAL 网络提取层(Network Abstraction Layer)

1.NAL全称Network Abstract Layer, 即网络抽象层。 在H.264/AVC视频编码标准中&#xff0c;无论是存储还是网络传输&#xff0c;H264 原始码流是由一个接一个 NALU&#xff08;NAL Unit&#xff09; 组成&#xff0c;整个系统框架被分为两个层面&#xff1a;视频编码层面&#…

uniapp学习(003-1 vue3学习 Part.1)

零基础入门uniapp Vue3组合式API版本到咸虾米壁纸项目实战&#xff0c;开发打包微信小程序、抖音小程序、H5、安卓APP客户端等 总时长 23:40:00 共116P 此文章包含第11p-第p14的内容 文章目录 vue3使用介绍插值表达式例子时间戳随机数输出函数的值 ref响应式数据变量v-bind 绑…

PCL CropBox 过滤给定立方体内的点云数据

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1 点云裁剪 2.1.2 可视化原始点云和裁剪后的点云 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接&#xff1a; PCL点云算法与项目实战案例汇总&#xff08;长…

Python办公自动化案例:批量修改Word文件中的段落格式

案例:Python实现批量修改Word文件中的段落格式。 在处理大量Word文档时,经常需要批量修改这些文档的格式,比如统一段落格式,以提升文档的一致性和专业性。使用Python来实现这一任务可以极大地提高工作效率,特别是当涉及到数百或数千个文档时。Python通过第三方库如python…

【C#】CacheManager:高效的 .NET 缓存管理库

在现代应用开发中&#xff0c;缓存是提升性能和降低数据库负载的重要技术手段。无论是 Web 应用、桌面应用还是移动应用&#xff0c;缓存都能够帮助减少重复的数据查询和处理&#xff0c;从而提高系统的响应速度。然而&#xff0c;管理缓存并不简单&#xff0c;尤其是当你需要处…

《RabbitMQ篇》Centos7安装RabbitMQ

安装RabbitMQ 安装包网盘下载地址 链接&#xff1a;https://pan.baidu.com/s/1bG_nP0iCdAejkctFp1QztQ?pwd4mlw 先上传安装包到服务器&#xff08;erlang-23.3.4.11-1.el7.x86_64.rpm和rabbitmq-server-3.9.16-1.el7.noarch.rpm&#xff09;然后使用指令安装 # 安装 erlang r…