内置数据源
data:image/s3,"s3://crabby-images/ac9fb/ac9fbacb929fd6a039bbfa8cf720a3f5488a83e4" alt=""
我们回顾一下druid数据源的配置方式
通过type属性指定数据源的类型
data:image/s3,"s3://crabby-images/b33cd/b33cd1614928b35caa834d80cf49a396e3729a33" alt=""
导入依赖 starter就使用了spring的自动装配功能
格式二是在引入druid的依赖的基础上
进行的一种配置方式
data:image/s3,"s3://crabby-images/6d7ca/6d7ca63ca45d0a1b7be69d557eff095477b0c699" alt=""
Tomcat内部也可以进行数据源的配置
轻量级中最快的数据源对象
data:image/s3,"s3://crabby-images/59ba1/59ba15eb7d996d346d0e343416195ba2347b4ec0" alt=""
我们切换德鲁伊连接池
data:image/s3,"s3://crabby-images/5d3f9/5d3f962eba9052f0382c5ccfb8ad2f2faac24655" alt=""
我们查看一下hikari的配置
data:image/s3,"s3://crabby-images/9e8a6/9e8a64db5159040faf9f477919e808a15d5841b2" alt=""
小结
data:image/s3,"s3://crabby-images/f1079/f10797b4d444056887ec7a8543653eff7dbb8993" alt=""
data:image/s3,"s3://crabby-images/27abb/27abbd75a653e9c406fa032a4f6002223506cc71" alt=""
JdbcTemplate
默认的持久化的技术
data:image/s3,"s3://crabby-images/e0392/e039271b5bc68cf5f4e316161758b0c033889784" alt=""
简述
data:image/s3,"s3://crabby-images/14a1f/14a1f907fd627e0f0e9c4d3451124dba26ab2c46" alt=""
这个技术目前不太有人用
导入依赖
当我们导入JDBC starter 的依赖时
自动配置了数据源
是一个操作数据库的模版对象
data:image/s3,"s3://crabby-images/df869/df8693754339b10833bf313fd56fefed9b1c3805" alt=""
我们去掉Mybatis-plus的依赖后
就不能使用BaseMapper的接口
data:image/s3,"s3://crabby-images/32a61/32a61d436821121ec5f89523488dace05a81fa27" alt=""
而且数据层接口也不能加载为bean后注入测试
实操
这样进行测试
测试一下查询功能
我们首先要建立一个行列式模型
data:image/s3,"s3://crabby-images/1db48/1db480074c1d96b5ee9452ef4e3f1db6e41509b2" alt=""
把数据封装进去
然后定义sql语句
调用jdbcTemplate里面的方法
data:image/s3,"s3://crabby-images/e2a86/e2a86fa0e8a33c2b3ce2f8c3ecba5dcf1559d576" alt=""
这边要是写增删改
也是很简单
直接换sql语句就行哈
data:image/s3,"s3://crabby-images/82041/8204144a69d84a9d2112a38fef0f90422adbf80b" alt=""
小结
data:image/s3,"s3://crabby-images/57f7a/57f7a3669200299164dec6f422c52348dc43a167" alt=""
data:image/s3,"s3://crabby-images/24d27/24d27adfce13294394c01939849c447fec1224ac" alt=""
H2数据库
内存级的数据库
data:image/s3,"s3://crabby-images/c7891/c78913f1010570e078ba57feac9001c7173e44b9" alt=""
我们用内置数据源
和新的持久化技术
我们的数据库也可以换其他的内嵌数据库
data:image/s3,"s3://crabby-images/25d19/25d195aa3e25387d2a3e0faa763466d69c6572fc" alt=""
我们能把java程序放到spring容器里面
内嵌服务器是在内存里面
不是一个独立的程序
我们数据库代码书写量很小
而且启动起来都是在内存运行 测试
等到上线的时候直接换其他数据库如轻量级数据库MySQL
data:image/s3,"s3://crabby-images/f47b8/f47b80fa5c1062859756b64bc13ed9d716e335f5" alt=""
实操
我们启动的话
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
对于我们的H2数据库
我们也有界面
我们先要进行配置
spring:
datasource:
# 数据库
url: jdbc:h2:~/mydb
driver-class-name: org.h2.Driver
username: root
password: 123456
h2:
console:
path: /h2 #h2嵌入式数据库控制台,可以通过浏览器访问
enabled: true
本地路径
访问路径H2
我们找到了H2数据库和他的配置文件
data:image/s3,"s3://crabby-images/7b8c2/7b8c295209ba498d32181bd594767ccd3d71231d" alt=""
网页控制台
填写信息
data:image/s3,"s3://crabby-images/36324/3632420fa7bfa24165f16fccdefbb2ea8636adb2" alt=""
进入控制台
data:image/s3,"s3://crabby-images/0178f/0178f58470ce7596e7ba624fdfe56156c5237949" alt=""
创建表的语句
也是用SQL语句
data:image/s3,"s3://crabby-images/c774a/c774a0649f17bc5942e7b03a9d84c4f2a144bdb1" alt=""
点击表
会自动显示表的创建数据
data:image/s3,"s3://crabby-images/3a8f1/3a8f141ddd138ab677e0881ee923d2d55de98d4f" alt=""
插值语句
data:image/s3,"s3://crabby-images/efb3e/efb3e3932ad1c340f42ceacea1db9077912af5fd" alt=""
查询所有
data:image/s3,"s3://crabby-images/59e68/59e68b7668c799e3563b70b5b3674f9be9af5830" alt=""
测试
我们接下来要在java程序中使用H2数据库
我们接着用jdbcTemplate
进行插值语句的测试
data:image/s3,"s3://crabby-images/1aadb/1aadb47a7063ce2c2cc4ae7ebe33b8e15ad8913a" alt=""
jdbcTemplate读取的是配置文件
yml里面的datasource里面的配置
读取的是H2的配置
是一个内存级的数据库
package com.example.demo;
import com.example.demo.dao.GoodDao;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;
@SpringBootTest
class DemoApplicationTests {
@Test
void testJdbcTemplateSave(@Autowired JdbcTemplate jdbcTemplate){
String sql="insert into tbl_book values(3,'sb','sb')";
System.out.println(jdbcTemplate.update(sql));
}
}
这些技术
在换的时候简直是无缝衔接
小结
data:image/s3,"s3://crabby-images/31e88/31e886777cb6af27c3d27a4407a5b931b630b659" alt=""
data:image/s3,"s3://crabby-images/8c6d9/8c6d9d75f5cbf5480482158f259e5f185f8eba72" alt=""
这是一个非常大的安全隐患
记得上线的时候一定要把H2数据库关掉
小结
data:image/s3,"s3://crabby-images/82af0/82af063e3d1e4387b40fec5700a5fc66dcb6ce7a" alt=""
个人号推广
博客主页
Web后端开发
https://blog.csdn.net/qq_30500575/category_12624592.html?spm=1001.2014.3001.5482
Web前端开发
https://blog.csdn.net/qq_30500575/category_12642989.html?spm=1001.2014.3001.5482
数据库开发
https://blog.csdn.net/qq_30500575/category_12651993.html?spm=1001.2014.3001.5482
项目实战
https://blog.csdn.net/qq_30500575/category_12699801.html?spm=1001.2014.3001.5482
算法与数据结构
https://blog.csdn.net/qq_30500575/category_12630954.html?spm=1001.2014.3001.5482
计算机基础
https://blog.csdn.net/qq_30500575/category_12701605.html?spm=1001.2014.3001.5482
回忆录
https://blog.csdn.net/qq_30500575/category_12620276.html?spm=1001.2014.3001.5482