这边需要注意一点 , H2只支持最简单的建表语句 。比如索引、engine、charset、排序之类的都无法执行 。以下是我Mysql的建表语句供你参考
CREATE TABLE `sys_config` (`config_id` int NOT NULL AUTO_INCREMENT COMMENT '参数主键',`config_name` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '配置名称',`config_key` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '配置键名',`config_options` varchar(1024) NOT NULL DEFAULT '' COMMENT '可选的选项',`config_value` varchar(256) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '配置值',`is_allow_change` tinyint(1) NOT NULL COMMENT '是否允许修改',`creator_id` bigint DEFAULT NULL COMMENT '创建者ID',`creator_name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '创建者',`updater_id` bigint DEFAULT NULL COMMENT '更新者ID',`updater_name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '更新者',`update_time` datetime DEFAULT NULL COMMENT '更新时间',`create_time` datetime DEFAULT NULL COMMENT '创建时间',`remark` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '备注',`deleted` tinyint(1) NOT NULL DEFAULT '0' COMMENT '逻辑删除',PRIMARY KEY (`config_id`),UNIQUE KEY `config_key_uniq_idx` (`config_key`) USING BTREE) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='参数配置表';
可以发现Mysql的建表语句需要删除一部分特殊用法 , 才能在H2执行 。H2的建表语句显得很简单 。
3.yml中引入变量控制是否启用H2数据库# 如果需要无Mysql无Redis直接启动的话可以将这个参数置为true, 并且spring.profile.active: dev换成testagileboot:embedded-test: false
因为项目可以选择使用Mysql启动也可以使用H2启动 , Spring的配置会有冲突 。所以使用agileboot.embedded-test的值来决定启动Mysql相关的Bean还是H2相关的Bean.Spring提供了@ConditionalOnExpression注解基于条件来初始化bean
@Bean@ConfigurationProperties("spring.datasource.druid.master")@ConditionalOnExpression("'${agileboot.embedded-test}' != 'true'")public DataSource masterDataSource(DruidProperties druidProperties) {DruidDataSource dataSource = DruidDataSourceBuilder.create().build();return druidProperties.dataSource(dataSource);}
引入内置Redis代码实现1.引入依赖<dependency><groupId>it.ozimov</groupId><artifactId>embedded-redis</artifactId><version>0.7.3</version><!-- 不排除掉slf4j的话 会冲突--><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-simple</artifactId></exclusion></exclusions></dependency>
2.引入Embedded Redis进行启动@Configuration@ConditionalOnExpression("'${agileboot.embedded-test}' == 'true'")public class EmbeddedRedisConfig {@Value("${spring.redis.port}")private Integer port;private RedisServer redisServer;@PostConstructpublic void postConstruct() {RedisServer redisServer = RedisServer.builder().port(port).setting("maxheap 32M").setting("daemonize no").setting("appendonly no").build();this.redisServer = redisServer;redisServer.start();}@PreDestroypublic void preDestroy() {redisServer.stop();}}
同理 , 我们使用agileboot.embedded-test的值来决定启动内置的Redis.
该设计实现在AgileBoot项目内 , 有兴趣的小伙伴可以项目down下来看下~几行指令即可run起前后端项目 。后端项目仅需把yml的这两个配置改一下即可 。

文章插图
前后端全栈技术交流群:1398880
欢迎前后端萌新大佬加群讨论~~经验总结扩展阅读
- 教你如何解决T+0的问题
- 姐夫的姐夫如何称呼
- 深空之眼流萤岚雾休刻印如何搭配比较合适
- ipad如何分屏工作(ipad微信分屏怎么取消)
- ipad如何左右分屏(ipadcanvas上下分屏)
- ipad如何打开分屏模式(ipad如何关联分屏模式)
- TCP 序列号和确认号是如何变化的?
- 如何通过 C#/VB.NET 重命名 Excel 表格并设置选项卡颜色
- 2023年摩羯座财运1月运程详解如何提高
- 81年属鸡今年多大了2023 81年属鸡2023年运势发如何