SpringBoot数据库操作的应用
mhr18 2025-01-09 14:46 17 浏览 0 评论
1.JDBC+HikariDataSource
在SpringBoot 2.x项目中,默认使用Hikari连接池管理数据源。相比于传统的 C3P0 、DBCP、Tomcat jdbc 等连接池更加优秀。
当项目pom.xml引入spring-boot-starter-jdbc启动器依赖后,即可自动导入Hikari,该启动器不但依赖它,还会对其自动配置并创建数据源。我们以MySQL数据库为例,介绍如何使用Hikari。
数据源是啥?为什么要用?怎么用?
1.1应用实例
演示SpringBoot如何通过 JDBC+HikariDataSource 完成对Mysql操作。
(1)数据库和表
-- 创建数据库DROP DATABASE IF EXISTS spring_boot;CREATE DATABASE spring_boot;USE spring_boot; -- 创建表CREATE TABLE furn(`id` INT(11) PRIMARY KEY AUTO_INCREMENT, #id`name` VARCHAR(64) NOT NULL, #家居名`maker` VARCHAR(64) NOT NULL, #厂商`price` DECIMAL(11,2) NOT NULL, #价格`sales` INT(11) NOT NULL, #销量`stock` INT(11) NOT NULL, #库存`img_path` VARCHAR(256) NOT NULL #照片路径); -- 初始化家居数据INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , '北欧风格小桌子' , '熊猫家居' , 180 , 666 , 7 , 'assets/images/product-image/6.jpg'); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , '简约风格小椅子' , '熊猫家居' , 180 , 666 , 7 , 'assets/images/product-image/4.jpg'); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , '典雅风格小台灯' , '蚂蚁家居' , 180 , 666 , 7 , 'assets/images/product-image/14.jpg'); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , '温馨风格盆景架' , '蚂蚁家居' , 180 , 666 , 7 , 'assets/images/product-image/16.jpg'); SELECT * FROM furn;
(2)进行数据库开发,首先要在pom.xml文件中引入spring-boot-starter-data-jdbc。SpringBoot不知道项目要操作Mysql还是Oracle,因此还需要导入数据库驱动,并指定对应版本。
<!--进行数据库开发,引入data-jdbc starter--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jdbc</artifactId></dependency> <!--导入mysql驱动,如果使用版本仲裁,SpringBoot默认的版本为8.0.26--><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.49</version></dependency>
(3)在application.yml配置操作数据源的信息
spring: datasource: #配置数据源 #说明:如果没有配置useSSL=true,启动项目会报红警告,但不影响使用 url: jdbc:mysql://localhost:3306/spring_boot?useSSL=true&useUnicode=true&characterEncoding=UTF-8 username: root password: 123456 driver-class-name: com.mysql.jdbc.Driver
(4)创建Javabean--Furn.java
package com.li.thymeleaf.bean; import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor; import java.math.BigDecimal; /** * @author 李 * @version 1.0 */@Data@NoArgsConstructor@AllArgsConstructorpublic class Furn { private Integer id; private String name; private String maker; private BigDecimal price; private Integer sales; private Integer stock; private String imgPath;}
(5)测试类ApplicationTests.java
package com.li.thymeleaf; import com.li.thymeleaf.bean.Furn;import org.junit.jupiter.api.Test;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.jdbc.core.JdbcTemplate; import javax.annotation.Resource;import java.util.List; /** * @author 李 * @version 1.0 * 演示如何在SpringBoot中开发测试类 */@SpringBootTestpublic class ApplicationTests { //这里使用spring的JDBCTemplate @Resource private JdbcTemplate jdbcTemplate; @Test public void contextLoads() { //使用RowMapper接口来对返回的数据进行封装(底层是反射->setter) BeanPropertyRowMapper<Furn> rowMapper = new BeanPropertyRowMapper<>(Furn.class); List<Furn> furns = jdbcTemplate.query("select * from furn", rowMapper); for (Furn furn : furns) { System.out.println("furn=" + furn); } //查看底层使用的是什么数据源 System.out.println(jdbcTemplate.getDataSource().getClass()); }}
测试结果:
<!--要开发SpringBoot测试类,需要引入test starter--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId></dependency>
2.整合Druid到SpringBoot
2.1Druid介绍
alibaba/druid: 为监控而生的数据库连接池 (github.com)
官方使用文档 · alibaba/druid Wiki (github.com)
Druid数据库连接池性能优秀,它除了提供性能卓越的数据池功能外,还继承了SQL监控,黑名单拦截等功能。强大的监控特性,通过Druid提供的监控功能,可以清楚知道连接池和SQL的工作情况,所以根据项目需要,我们也要掌握Druid和SpringBoot的整合。
整合Druid到SpringBoot的方式:
- 自定义方式
- 引入starter
2.2Druid基本使用
(1)修改pom.xml,引入druid依赖
<!--引入druid依赖--><dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.17</version></dependency>
(2)创建配置类 DruidDataSourceConfig.java,将DruidDataSource注入容器
package com.li.thymeleaf.config; import com.alibaba.druid.pool.DruidDataSource;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; /** * @author 李 * @version 1.0 * 配置类 */@Configurationpublic class DruidDataSourceConfig { //注入DruidDataSource //通过@ConfigurationProperties指定读取application.yml文件的数据 //我们就不需要调用DruidDataSource的setXxx方法来配置(不推荐) @ConfigurationProperties("spring.datasource") @Bean public DataSource dataSource() { return new DruidDataSource(); }}
(3)测试类ApplicationTests.java(略,同上)
测试结果:
2.2.1一个问题
问题:为什么我们注入了自己的数据源,默认的HikariDataSource就失效了?
先来弄明白,默认的HikariDataSource 是如何配置的:
SpringBoot通过DataSourceAutoConfiguration.java来进行数据源的配置,在进行默认的配置之前,如果检测到容器中已经有DataSource Bean,就不会注入默认的HikariDataSource。
因此,如果你注入了自己的数据源,就不会注入默认的HikariDataSource。
DataSourceAutoConfiguration.java:
2.3Druid监控功能
2.3.1开启内置监控页
怎样使用Druid的内置监控页面:内置监控页面是一个Servlet,具体配置看这里
(1)在配置类中,启用druid的监控页功能:
在web项目中使用web.xml配置,若在SpringBoot中,有两种方法注入Servlet---注解和RegistrationBean,这里使用RegistrationBean
DruidDataSourceConfig.java:
package com.li.thymeleaf.config; import com.alibaba.druid.pool.DruidDataSource;import com.alibaba.druid.support.http.StatViewServlet;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.boot.web.servlet.ServletRegistrationBean;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; /** * @author 李 * @version 1.0 * 配置类 */@Configurationpublic class DruidDataSourceConfig { //注入DruidDataSource //通过@ConfigurationProperties指定读取yml文件的前缀的数据 @ConfigurationProperties("spring.datasource") @Bean public DataSource dataSource() { return new DruidDataSource(); } //配置Druid的监控页功能 @Bean public ServletRegistrationBean statViewServlet() { //创建StatViewServlet ServletRegistrationBean<StatViewServlet> registrationBean = new ServletRegistrationBean<>(new StatViewServlet(), "/druid/*"); //设置初始化参数-用户名和密码-根据官方配置文件设置 registrationBean.addInitParameter("loginUsername", "olien"); registrationBean.addInitParameter("loginPassword", "123456"); return registrationBean; }}
(2)启动项目,浏览器中访问http://项目ip:项目端口/项目名称/druid/index.html,输入配置的用户名和密码,即可访问到内置的监控页面:
2.3.2SQL监控
配置_StatFilter · alibaba/druid Wiki (github.com)
除了文档中的配置方式,也可在配置类中直接对数据源进行设置。
修改DruidDataSourceConfig.java:
启用SQL监控功能之后,在监控页中可以查看到所有对数据库发出的SQL语句:
2.3.3-Web关联监控
Web关联监控配置
Spring关联监控配置
修改DruidDataSourceConfig.java:注入webStatFilter
//配置WebStatFilter,用于采集web-jdbc关联的监控数据@Beanpublic FilterRegistrationBean webStatFilter() { //创建过滤器webStatFilter WebStatFilter webStatFilter = new WebStatFilter(); FilterRegistrationBean<WebStatFilter> filterRegistrationBean = new FilterRegistrationBean<>(webStatFilter); //设置webStatFilter的监控url filterRegistrationBean.setUrlPatterns(Arrays.asList("/*")); //根据官方文档设置webStatFilter排除的url filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"); return filterRegistrationBean;}
启用URI监控功能之后,在监控页中可以查看到所有的Web应用情况和URI请求情况:
2.3.4SQL防火墙
Druid提供了WallFilter,它是基于SQL语义分析来实现防御SQL注入攻击的。具体配置看这里
修改DruidDataSourceConfig.java:
启用SQL防火墙之后,在监控页中可以查看到所有的SQL情况:
2.3.5Session监控
注意:这里的Session不包括Druid后台监控系统产生的Session
Druid的Session监控不需要配置,在开启了内置监控功能后就可以使用了。
2.4Druid-Starter
整合Druid到SpringBoot的方式有两种:自定义方式和引入starter。
2.3中的所有例子中我们使用的是自己引入druid+配置类方式整合druid和监控。此外,还可以引入Druid Srping Boot Starter,让程序员在SpringBoot项目中更加轻松集成Druid和监控。
演示使用Druid-Starter(演示之前,删除之前所有的自定义方式操作)
(1)pom.xml引入druid-spring-boot-starter
<!--引入druid的starter--><dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.17</version></dependency>
(2)在application.yml文件中配置druid和监控功能
spring: datasource: #配置数据源 #如果没有配置useSSL=true,启动项目会报红警告,但不影响使用 url: jdbc:mysql://localhost:3306/spring_boot?useSSL=true&useUnicode=true&characterEncoding=UTF-8 username: root password: 123456 driver-class-name: com.mysql.jdbc.Driver #配置druid和监控功能 druid: stat-view-servlet: #(1)开启监控页 enabled: true login-username: jack login-password: 1234 reset-enable: false web-stat-filter: #(2)启用web监控功能 enabled: true url-pattern: /* exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" filter: stat: #(3)启用sql监控功能 slow-sql-millis: 1000 #单位ms log-slow-sql: true #启用慢查询的sql日志 enabled: true wall: #(4)启用sql防火墙功能 enabled: true config: drop-table-allow: false #是否允许进行删除表的操作 select-all-column-allow: false #是否允许查询所有字段的操作
3.练习
将异常处理、注入Servlet、Filter、Listener,Tomcat切换,数据库操作(HikariDataSource&DruidDataSource)相关代码和案例写一遍
相关推荐
- redis 7.4.3更新!安全修复+性能优化全解析
-
一、Redis是什么?为什么选择它?Redis(RemoteDictionaryServer)是一款开源的高性能内存键值数据库,支持持久化、多数据结构(如字符串、哈希、列表等),广泛应用于缓存、消...
- C# 读写Redis数据库的简单例子
-
CSRedis是一个基于C#的Redis客户端库,它提供了与Redis服务器进行交互的功能。它是一个轻量级、高性能的库,易于使用和集成到C#应用程序中。您可以使用NuGet包管理器或使用以下命令行命令...
- 十年之重修Redis原理
-
弱小和无知并不是生存的障碍,傲慢才是。--------面试者总结Redis可能都用过,但是从来没有理解过,就像一个熟悉的陌生人,本文主要讲述了Redis基本类型的使用、数据结构、持久化、单线程模型...
- 高频L2行情数据Redis存储架构设计(含C++实现代码)
-
一、Redis核心设计原则内存高效:优化数据结构,减少内存占用低延迟访问:单次操作≤0.1ms响应时间数据完整性:完整存储所有L2字段实时订阅:支持多客户端实时数据推送持久化策略:RDB+AOF保障数...
- Magic-Boot开源引擎:零代码玩转企业级开发,效率暴涨!
-
一、项目介绍基于magic-api搭建的快速开发平台,前端采用Vue3+naive-ui最新版本搭建,依赖较少,运行速度快。对常用组件进行封装。利用Vue3的@vue/compiler-sfc单文...
- 项目不行简历拉胯?3招教你从面试陪跑逆袭大厂offer!
-
项目不行简历拉胯?3招教你从面试陪跑逆袭大厂offer!老铁们!是不是每次面试完都感觉自己像被大厂面试官婉拒的渣男?明明刷了三个月题库,背熟八股文,结果一被问项目就支支吾吾,简历写得像大学生课程设计?...
- 谷歌云平台:开发者部署超120个开源包
-
从国外相关报道了解,Google与Bitnami合作为Google云平台增加了一个新的功能,为了方便开发人员快捷部署程序,提供了120余款开源应用程序云平台的支持。这些应用程序其中包括了WordPre...
- 知名互联网公司和程序员都看好的数据库是什么?
-
2017年数据库领域的最大趋势是什么?什么是最热的数据处理技术?学什么数据库最有前途?程序员们普遍不喜欢的数据库是什么?本文都会一一揭秘。大数据时代,数据库的选择备受关注,此前本号就曾揭秘国内知名互联...
- 腾讯云发布云存储MongoDB服务
-
近日,著名安全专家兼Shodan搜索引擎的创建者JohnMatherly发现,目前至少有35000个受影响的MongoDB数据库暴露在互联网上,它们所包含的数据暴露在网络攻击风险之中。据估计,将近6...
- 已跪,Java全能笔记爆火,分布式/开源框架/微服务/性能调优全有
-
前言程序员,立之根本还是技术,一个程序员的好坏,虽然不能完全用技术强弱来判断,但是技术水平一定是基础,技术差的程序员只能CRUD,技术不深的程序员也成不了架构师。程序员对于技术的掌握,除了从了解-熟悉...
- 面试官:举个你解决冲突的例子?别怂!用这个套路……
-
面试官:举个你解决冲突的例子?别怂!用这个套路……最近收到粉丝私信,说被问到:团队技术方案有分歧怎么办?当场大脑宕机……兄弟!这不是送命题,是展示你情商+技术判断力的王炸题!今天教你们3招,用真实案例...
- 面试碰到MongoDB?莫慌,跟面试官这样吹MongoDB 复制集
-
推荐阅读:吊打MySQL:21性能优化实践+学习导图+55面试+笔记+20高频知识点阿里一线架构师分享的技术图谱,进阶加薪全靠它十面字节跳动,依旧空手而归,我该放弃吗?文末会分享一些MongoDB的学...
- SpringBoot集成扩展-访问NoSQL数据库之Redis和MongoDB!
-
与关系型数据库一样,SpringBoot也提供了对NoSQL数据库的集成扩展,如对Redis和MongoDB等数据库的操作。通过默认配置即可使用RedisTemplate和MongoTemplate...
- Java程序员找工作总卡项目关?
-
Java程序员找工作总卡项目关?3招教你用真实经历写出HR抢着要的简历!各位Java老哥,最近刷招聘软件是不是手都划酸了?简历投出去石沉大海,面试邀请却总在飞别人的简历?上周有个兄弟,13年经验投了5...
- Java多租户SaaS系统实现方案
-
嗯,用户问的是Java通过租户id实现的SaaS方案。首先,我需要理解用户的需求。SaaS,也就是软件即服务,通常是指多租户的架构,每个租户的数据需要隔离。用户可能想知道如何在Java中利用租户ID来...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)