SpringBoot SpringBoot 开发实用篇 4 数据层解决方案 4.1 内置数据源
创始人
2024-01-29 13:09:13
0

SpringBoot

【黑马程序员SpringBoot2全套视频教程,springboot零基础到项目实战(spring boot2完整版)】

SpringBoot 开发实用篇

文章目录

      • SpringBoot
      • SpringBoot 开发实用篇
      • 4 数据层解决方案
        • 4.1 内置数据源
          • 4.1.1 现有数据层解决方案
          • 4.1.2 小结

4 数据层解决方案

4.1 内置数据源

4.1.1 现有数据层解决方案

Druid + MyBatis-Plus + MySQL

  • 数据源:DruidDataSource
  • 持久化技术:MyBatis-Plus / MyBatis
  • 数据库:MySQL

在我们之前的工程中

在这里插入图片描述

这两个其实我们是没有配置druid 数据源的,难道它就没有用到数据源技术吗?

【答案当然是否定的】

【对于druid 的数据源配置格式】

两种

在这里插入图片描述

下面这种格式需要导入druid 的starter 坐标

【如果我没有指定这个,它的数据源是什么?】

【创建新模块】

创建一个新的模块

在这里插入图片描述

依赖都不勾

在这里插入图片描述

直接创建

在这里插入图片描述

一个全新的 SpringBoot 工程

手动添加依赖

org.projectlomboklombok
com.baomidoumybatis-plus-boot-starter3.5.2
com.alibabadruid-spring-boot-starter1.2.11
mysqlmysql-connector-javaruntime

就是这些基本的

在这里插入图片描述

创建实体类

package com.dingjiaxiong.domain;import lombok.Data;/*** ClassName: Book* date: 2022/10/20 10:52** @author DingJiaxiong*/@Data
public class Book {private int id;private String name;private String type;private String description;}

数据层接口

package com.dingjiaxiong.dao;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.dingjiaxiong.domain.Book;
import org.apache.ibatis.annotations.Mapper;/*** ClassName: BookDao* date: 2022/10/20 10:53** @author DingJiaxiong*/@Mapper
public interface BookDao extends BaseMapper {
}

配置文件

spring:datasource:druid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTCusername: rootpassword: 200039mybatis-plus:global-config:db-config:table-prefix: tbl_id-type: autoconfiguration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

编写测试类

package com.dingjiaxiong;import com.dingjiaxiong.dao.BookDao;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
class Springboot15SqlApplicationTests {@Autowiredprivate BookDao bookDao;@Testvoid test() {bookDao.selectById(1);}}

测试结果

在这里插入图片描述

OK,没问题

看看druid 在哪儿

在这里插入图片描述

在这里插入图片描述

再下面就是数据库操作了

【两种配置druid 的方式运行出来没有区别】

现在我不想用druid 了

在这里插入图片描述

再运行测试

在这里插入图片描述

成功了,

仔细观察

在这里插入图片描述

我好像没用,但是还是用了【哈哈哈哈哈】

【为什么】

现在加载的druid 是SpringBoot 的自动配置功能,我们导入了starter 之后,它就有这功能了

在这里插入图片描述

现在直接把它注掉

在这里插入图片描述

再次运行

在这里插入图片描述

运行成功了,而且好像有个新的数据源

这就是我们啥也没配的情况下,SpringBoot 默认的数据源

【介绍一下】

SpringBoot提供了3种内嵌的数据源对象供开发者选择

  • HikariCP【默认】【超快】
  • Tomcat提供DataSource
  • commons DBCP

对Hikari 做进一步的配置

在这里插入图片描述

spring:datasource:url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTChikari:driver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: 200039

改成这样子,再测试一次

在这里插入图片描述

OK, 依然可以正常使用

url 不能拿下来

还有其他很多hikari数据源 专用的配置

回顾一下

在这里插入图片描述

在这里插入图片描述

4.1.2 小结
  1. SpringBoot内置3款数据源可供选择
  • HikariCP(默认)
  • Tomcat提供DataSource
  • Commons DBCP

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...