springboot 启动加载数据文件data.sql + 游标和存储过程的灵活使用

为何要这么使用呢?

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; $$  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值