Spring Boot 连接 MySQL 数据库(spring boot配置数据库连接)
itomcoil 2025-07-03 15:56 6 浏览
一、环境准备
1.1 依赖管理(Maven)
<!-- 方案1:JdbcTemplate -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!-- 方案2:MyBatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>3.0.5</version>
</dependency>
<!-- 方案3:Spring Data JPA -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!-- 通用依赖 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
二、核心配置
2.1 application.yml 配置
spring:
datasource:
url: jdbc:mysql://localhost:3306/springboot_demo?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8
username: springboot_user
password: SecurePass123!
driver-class-name: com.mysql.cj.jdbc.Driver
hikari:
maximum-pool-size: 20
minimum-idle: 5
idle-timeout: 30000
connection-timeout: 30000
max-lifetime: 1800000
# JPA配置(方案3适用)
jpa:
show-sql: true
hibernate:
ddl-auto: update # options: create/create-drop/update/validate
properties:
hibernate:
dialect: org.hibernate.dialect.MySQL8Dialect
三、三种实现方案
3.1 使用 JdbcTemplate(基础方案)
3.1.1 DAO 层实现
@Repository
public class UserDao {
@Autowired
private JdbcTemplate jdbcTemplate;
public List<User> findAll() {
return jdbcTemplate.query("SELECT * FROM users",
(rs, rowNum) -> new User(
rs.getLong("id"),
rs.getString("username"),
rs.getString("email")
));
}
public User save(User user) {
jdbcTemplate.update(
"INSERT INTO users (username, email) VALUES (?, ?)",
user.getUsername(), user.getEmail()
);
return user;
}
}
3.2 集成 MyBatis(推荐方案)
3.2.1 Mapper 接口
@Mapper
public interface UserMapper {
@Select("SELECT * FROM users WHERE id = #{id}")
User findById(@Param("id") Long id);
@Insert("INSERT INTO users(username,email) VALUES(#{username},#{email})")
@Options(useGeneratedKeys = true, keyProperty = "id")
void insert(User user);
}
3.2.2 XML 映射(复杂查询)
<!-- src/main/resources/mappers/UserMapper.xml -->
<mapper namespace="com.example.demo.mapper.UserMapper">
<resultMap id="UserResultMap" type="User">
<id column="id" property="id"/>
<result column="username" property="username"/>
<result column="email" property="email"/>
</resultMap>
<select id="findByEmail" resultMap="UserResultMap">
SELECT * FROM users WHERE email = #{email}
</select>
</mapper>
3.3 Spring Data JPA(ORM方案)
3.3.1 实体类定义
@Entity
@Table(name = "users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(nullable = false, unique = true)
private String username;
@Column(nullable = false, length = 100)
private String email;
// Getters/Setters
}
3.3.2 Repository 接口
public interface UserRepository extends JpaRepository<User, Long> {
Optional<User> findByEmail(String email);
@Query("SELECT u FROM User u WHERE u.username LIKE %:keyword%")
List<User> searchByUsername(@Param("keyword") String keyword);
}
四、服务层与控制器
4.1 服务层实现
@Service
@Transactional
public class UserService {
@Autowired
private UserRepository userRepository;
public Page<User> findAll(Pageable pageable) {
return userRepository.findAll(pageable);
}
@Transactional
public User createUser(User user) {
return userRepository.save(user);
}
}
4.2 REST 控制器
@RestController
@RequestMapping("/api/users")
public class UserController {
@Autowired
private UserService userService;
@GetMapping
public ResponseEntity<Page<User>> getAllUsers(
@PageableDefault(size = 20, sort = "id", direction = Sort.Direction.ASC) Pageable pageable
) {
return ResponseEntity.ok(userService.findAll(pageable));
}
@PostMapping
public ResponseEntity<User> createUser(@RequestBody User user) {
return ResponseEntity.status(HttpStatus.CREATED).body(userService.createUser(user));
}
}
五、高级配置
5.1 连接池监控(HikariCP)
management:
endpoint:
health:
show-details: always
endpoints:
web:
exposure:
include: health,info,metrics,hikaricp
5.2 事务管理
@Transactional(
propagation = Propagation.REQUIRED,
isolation = Isolation.READ_COMMITTED,
timeout = 30,
rollbackFor = {SQLException.class, RuntimeException.class}
)
public void batchOperation() {
// 批量操作
}
相关推荐
- 麦克斯韦方程高斯-博内-陈定理嘉当外微分斯托克斯方程之间的联系
-
一、麦克斯韦方程的外微分形式1.电磁场张量的几何表示在微分几何中,电磁场由2-形式F描述,称为电磁场强形式:其中E为电场,B为磁场,dt为时间坐标。2.麦克斯韦方程的微分形式第二式(无...
- 机器视觉(四):空域图像增强(常见的空域图像增强处理方法有哪些)
-
一、图像处理技术概述1.定义对原始获取图像进行一系列的运算处理,称为图像处理。图像处理是机器视觉技术的方法基础,包括图像增强、边缘提取、图像分割、形态学处理、图像投影、配准定位和图像特征提取等方法。2...
- 基于机器视觉的安全气囊检测系统研究
-
21世纪以来,汽车行业发展迅猛。安全气囊作为汽车的安全辅助工具,它的出现大大降低了死亡率,因而必须确保其尺寸精确,并能正常使用。对安全气囊传统的检测方法主要是借助千分表、轮廓仪等工具进行人工抽检[...
- 高斯泼溅综合指南(高斯pp)
-
高斯泼溅(GaussianSplatting)是一种表示3D场景和渲染新视图的方法,在“实时辐射场渲染的3D高斯泼溅”中引入。它可以被认为是NeRF类模型的替代品,就像当年的NeRF...
- 基于DSP和ARM的电气化铁路接触线覆冰监测系统设计
-
张学武(中铁第一勘察设计院集团有限公司,陕西西安710043)摘要:为预防接触线上的冰害事故以及为除冰融冰提供支持,设计了集成视频传输、覆冰厚度测量、导线温度测量、现场微气象采集的接触线覆冰监测系...
- OpenCV 线性滤波(opencv 线性拟合)
-
OpenCV线性滤波线性滤波图像滤波与滤波器图像滤波,指的是在尽量保留图像特征的条件下对目标图像得噪声进行抑制,是图像处理当中不可缺少的部分。平滑录播室低频增强的空间域滤波技术,它的目的有两类:一类...
- 几种典型的图像去噪算法总结(图像去噪的定义)
-
(一)高斯低通滤波去噪高斯低通滤波器(GaussianLowPassFilter)是一类传递函数为高斯函数的线性平滑滤波器。又由于高斯函数是正态分布的密度函数。因此高斯低通滤波器对于去除服从正态...
- 深度解析卷积:从原理到应用(卷积到底是什么)
-
一、卷积的基本概念卷积是一种在数学领域尤其是分析数学中占据重要地位的运算方式。它通过两个函数和来生成第三个函数。设和是上的两个可积函数,卷积的积分表达式为:。在离散情况下,卷积定义为。从...
- 基于混合高斯模型的物体成分拟合方法
-
郎波,樊一娜,黄静,王鹏(北京师范大学珠海分校信息技术学院,广东珠海519087)为了寻求代价更小、效率更高、适应性更强的图像原型表征方法,借鉴成分识别理论的观点,设计出一种更符合人类认知原...
- 30天Python 入门到精通(python入门到精通书籍)
-
以下是一个为期30天的Python入门到精通学习课程,专为零基础新手设计。课程从基础语法开始,逐步深入到面向对象编程、数据处理,最后实现运行简单的大语言模型(如基于HuggingFace...
- Python 最好用的 8 个 VS Code 扩展
-
1.PythonextensionforVisualStudioCode这个扩展是由微软官方提供的,支持但不仅限于以下功能:通过Pylint或Flake8支持代码检查在VSCo...
- Textual:为 Python 增加漂亮的文本用户界面(TUI)
-
导读:如果你的代码是用Python编写的,你应该使用Textual来帮助你编写TUI(文本用户界面)。快速入门使用TextualPython在Linux上有像TkInterdocs...
- pytest框架进阶自学系列 | 常用插件的使用
-
书籍来源:房荔枝梁丽丽《pytest框架与自动化测试应用》一边学习一边整理老师的课程内容及实验笔记,并与大家分享,侵权即删,谢谢支持!附上汇总贴:pytest框架进阶自学系列|汇总_热爱编程的通...
- ShapeNet数据集及dataset代码分析
-
1.数据集简介ShpaeNet是点云中一个比较常见的数据集,它能够完成部件分割任务,即部件知道这个点云数据大的分割,还要将它的小部件进行分割。它总共包括十六个大的类别,每个大的类别有可以分成若干个小类...
- 「教程」5 分钟带你入门 kivy(怎么学kp)
-
原创:星安果AirPythonkivy语言通过编写界面UI,然后利用Python定义一些业务逻辑,可以移植很多功能模块到移动端直接执行。下面对kivy常见用法做一个汇总。1、什么是...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)