为何要这么使用呢?
1、可以防止项目在开发时误删程序运行必备数据,
2、特方便,简洁(只需要把写好的数据库脚本写成文件放入工程目录下,在你的yml,或properties文件里写上一点配置就好)!
在开发中有这两点理由我觉得完全足够了。
开始使用
后台配置:
spring:
datasource:
# 这句话的意思是(初始化模式(springboot2.0),其中有三个值,always为始终执行初始化,
# embedded只初始化内存数据库(默认值),如h2等,never为不执行初始化。)
initialization-mode: always
# 这是支撑程序运行必须要有的表的sql脚本
schema: classpath:sql/dcp.sql
# 这个文件就是表数据文件了
data: classpath:sql/data.sql
# sql脚本分割符,默认是‘;’,必须设置成其他字符才能创建存储过程,这个后面能用到,结束存储过程的标志
separator: $$
启动所需配置文件就全部在这里了,怎么样 简单吧。
但是我们在运行他的表数据时怎么知道他会不会按照我们的预期运行呢.,下面就是要用到我们的游标和存储过程了
/*有则删除*/
DROP PROCEDURE IF EXISTS p_init_user; $$
/*创建存储过程*/
CREATE PROCEDURE p_init_user()
/*开始内容*/
BEGIN
/*创建一个游标参数为整形 ,这里就是使用游标的灵活之处了,他的后面可以是一个查询集合!*/
DECLARE row_num INT;
/*统计表的总条数,赋值给游标,用来执行插入条件*/
SELECT COUNT(*) INTO row_num FROM t_user;
/*如果他的查询数量等于零那么他将会执行下面的插入语句*/
IF row_num = 0 THEN
INSERT INTO t_user(id,userName,password,personName,enabled) VALUES ('00001', 'admin','123456','admin',1);
/*结束这个判断*/
END IF;
/*逻辑和上面一样的*/
SELECT COUNT(*) INTO row_num FROM t_role;
IF row_num = 0 THEN
INSERT INTO t_role(id,name,level,status) VALUES ('00001', '超级管理员',1,1);
INSERT INTO t_role(id,name,level,status) VALUES ('00002', '管理员',2,1);
INSERT INTO t_role(id,name,level,status) VALUES ('00003', '操作员',3,1);
END IF;
/*逻辑和上面一样的*/
SELECT COUNT(*) INTO row_num FROM t_user_role;
IF row_num = 0 THEN
INSERT INTO t_user_role(id,userId,roleId) VALUES ('00001', '00001','00001');
END IF;
/*结束这个存储过程,*/
/* # sql脚本分割符,默认是‘;’,必须设置成其他字符才能创建存储过程*/
END; $$