背景介绍
为什么我们需要内置的数据库和Redis呢?
优点:
- 内置的数据库H2,可以让我们在无依赖数据库的情况下,做集成测试。比如我们想测试添加一个学生到数据库,就需要启动一台数据库来验证结果。然而使用H2内置数据库的话,就可以在无依赖数据库的情况下,进行验证。
- 数据库H2是内存级的,如果有大量集成测试(IT:Integration Test)的话,可以缩短测试时间。
- Embedded Redis同上,使我们在无依赖Redis的情况下,做测试。
- 还有一个小优点,就是对于新手或者不熟悉后端的前端小伙伴来说,他们在可以不配置Mysql和Redis就直接把整个项目run起来~
缺点:
- H2并不能兼容所有数据库的功能,比如函数,或者一些特殊索引之类的。使用H2的话,Mysql的表结构不能直接导入,需要做一些调整。
- Embeded Redis同样不能完全兼容真正的Redis, 一些特殊用法可能会出错。
引入H2数据库代码实现
1.引入内置的H2数据库
因为我想做到使用H2直接启动项目,所以scope设置为runtime,如果仅用H2做测试用的话,请设置成test
2.yml文件内数据库的配置,改成H2
最后两行是H2数据库需要的数据库结构和数据脚本文件,放置在resources文件夹下的h2sql目录里(你也可以放在其他目录) 以下是样本: schema.sql
data.sql
这边需要注意一点,H2只支持最简单的建表语句。 比如索引、engine、charset、排序之类的都无法执行。以下是我Mysql的建表语句供你参考
可以发现Mysql的建表语句需要删除一部分特殊用法,才能在H2执行。H2的建表语句显得很简单。
3.yml中引入变量控制是否启用H2数据库
因为项目可以选择使用Mysql启动也可以使用H2启动,Spring的配置会有冲突。所以使用agileboot.embedded-test的值来决定启动Mysql相关的Bean还是H2相关的Bean. Spring提供了@ConditionalOnExpression注解基于条件来初始化bean
引入内置Redis代码实现
1.引入依赖
2.引入Embedded Redis进行启动
同理,我们使用agileboot.embedded-test的值来决定启动内置的Redis.
该设计实现在AgileBoot项目内,有兴趣的小伙伴可以项目down下来看下~ 几行指令即可run起前后端项目。
后端项目仅需把yml的这两个配置改一下即可。