本项目地址:
- github: https://github.com/valarchie/AgileBoot-Back-End
- gitee: https://gitee.com/valarchie/AgileBoot-Back-End
背景介绍为什么我们需要内置的数据库和Redis呢?
优点:
- 内置的数据库H2 , 可以让我们在无依赖数据库的情况下 , 做集成测试 。比如我们想测试添加一个学生到数据库 , 就需要启动一台数据库来验证结果 。然而使用H2内置数据库的话 , 就可以在无依赖数据库的情况下 , 进行验证 。
- 数据库H2是内存级的 , 如果有大量集成测试(IT:Integration Test)的话 , 可以缩短测试时间 。
- Embedded Redis同上 , 使我们在无依赖Redis的情况下 , 做测试 。
- 还有一个小优点 , 就是对于新手或者不熟悉后端的前端小伙伴来说 , 他们在可以不配置Mysql和Redis就直接把整个项目run起来~
【AgileBoot - 如何集成内置数据库H2和内置Redis】缺点:
- H2并不能兼容所有数据库的功能 , 比如函数 , 或者一些特殊索引之类的 。使用H2的话 , Mysql的表结构不能直接导入 , 需要做一些调整 。
- Embeded Redis同样不能完全兼容真正的Redis, 一些特殊用法可能会出错 。
<dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency>
2.yml文件内数据库的配置 , 改成H2# 数据源配置spring:datasource:#驱动driver-class-name: org.h2.Driver# h2 内存数据库 内存模式连接配置 库名: agilebooturl: jdbc:h2:mem:agileboot;DB_CLOSE_DELAY=-1h2:# 开启console 访问 默认falseconsole:enabled: truesettings:#开启h2 console 跟踪 方便调试默认 falsetrace: true#允许console 远程访问 默认falseweb-allow-others: true#h2 访问路径上下文path: /h2-consolesql:init:platform: mysql# 初始化数据schema-locations: classpath:h2sql/agileboot_schema.sqldata-locations: classpath:h2sql/agileboot_data.sql
最后两行是H2数据库需要的数据库结构和数据脚本文件 , 放置在resources文件夹下的h2sql目录里(你也可以放在其他目录)以下是样本:schema.sqlcreate table sys_config(config_idint auto_increment,config_namevarchar(128)default '' not null comment '配置名称',config_keyvarchar(128)default '' not null comment '配置键名',config_optionsvarchar(1024) default '' not null comment '可选的选项',config_valuevarchar(256)default '' not null comment '配置值',is_allow_change intnot null comment '是否允许修改',creator_idintnull comment '创建者ID',creator_namevarchar(64)default '' null comment '创建者',updater_idintnull comment '更新者ID',updater_namevarchar(64)default '' null comment '更新者',update_timedatetimenull comment '更新时间',create_timedatetimenull comment '创建时间',remarkvarchar(128)null comment '备注',deletedintdefault 0not null comment '逻辑删除');
data.sql-- ------------------------------ Records of sys_config-- ----------------------------INSERT INTO `sys_config` VALUES ('1', '主框架页-默认皮肤样式名称', 'sys.index.skinName', '["skin-blue","skin-green","skin-purple","skin-red","skin-yellow"]', 'skin-blue', '1', null, 'admin', null, '', '2022-08-28 22:12:19', '2022-05-21 08:30:55', '蓝色 skin-blue、绿色 skin-green、紫色 skin-purple、红色 skin-red、黄色 skin-yellow', '0');INSERT INTO `sys_config` VALUES ('2', '用户管理-账号初始密码', 'sys.user.initPassword', '', '1234567', '1', null, 'admin', null, '', '2022-08-28 21:54:19', '2022-05-21 08:30:55', '初始化密码 123456', '0');INSERT INTO `sys_config` VALUES ('3', '主框架页-侧边栏主题', 'sys.index.sideTheme', '["theme-dark","theme-light"]', 'theme-dark', '1', null, 'admin', null, '', '2022-08-28 22:12:15', '2022-08-20 08:30:55', '深色主题theme-dark , 浅色主题theme-light', '0');INSERT INTO `sys_config` VALUES ('4', '账号自助-验证码开关', 'sys.account.captchaOnOff', '["true","false"]', 'false', '0', null, 'admin', null, '', '2022-08-28 22:03:37', '2022-05-21 08:30:55', '是否开启验证码功能(true开启 , false关闭)', '0');INSERT INTO `sys_config` VALUES ('5', '账号自助-是否开启用户注册功能', 'sys.account.registerUser', '["true","false"]', 'true', '0', null, 'admin', '1', 'admin', '2022-10-05 22:18:57', '2022-05-21 08:30:55', '是否开启注册用户功能(true开启 , false关闭)', '0');
经验总结扩展阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 教你如何解决T+0的问题
- 姐夫的姐夫如何称呼
- 深空之眼流萤岚雾休刻印如何搭配比较合适
- ipad如何分屏工作(ipad微信分屏怎么取消)
- ipad如何左右分屏(ipadcanvas上下分屏)
- ipad如何打开分屏模式(ipad如何关联分屏模式)
- TCP 序列号和确认号是如何变化的?
- 如何通过 C#/VB.NET 重命名 Excel 表格并设置选项卡颜色
- 2023年摩羯座财运1月运程详解如何提高
- 81年属鸡今年多大了2023 81年属鸡2023年运势发如何