spring-boot 在启动运行脚本中执行修改表结构
Posted 钟政123
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring-boot 在启动运行脚本中执行修改表结构相关的知识,希望对你有一定的参考价值。
spring-boot可以通过简单的配置,就可以直接sql文件执行创建表。但是该文件默认以“;”作为结束,在修改表结构中,需要用到存储过程。存储过程中需要用到";"。就会出现执行错误。好坑!
解决方案:
增加更改spring-boot的sql执行的结束符号的配置,以后在sql文件的结束就是以“$$”
spring.datasource.separator=$$
sql文件,功能先验证表是否存在某个字段,如果不存在则创建该字段。
/* 充电审计 - 主表增加字段 */ drop procedure if exists add_col_homework$$ create procedure add_col_homework() BEGIN IF NOT EXISTS (SELECT column_name FROM information_schema.columns WHERE TABLE_NAME = ‘ChargeOpAudition‘ AND column_name = ‘remarks‘) THEN ALTER TABLE `ChargeOpAudition` ADD COLUMN `remarks` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ; END IF; IF NOT EXISTS(SELECT column_name FROM INFORMATION_SCHEMA.COLUMNS WHERE column_name=‘transactionidStart‘ AND table_name=‘ChargeOpAudition‘ AND table_schema=‘ztev_db‘) THEN ALTER TABLE `ChargeOpAudition` ADD COLUMN `transactionidStart` varchar(100) DEFAULT null COMMENT ‘开始交易号‘ ; END IF; IF NOT EXISTS(SELECT column_name FROM INFORMATION_SCHEMA.COLUMNS WHERE column_name=‘state‘ AND table_name=‘ChargeOpAudition‘ AND table_schema=‘ztev_db‘) THEN ALTER TABLE `ChargeOpAudition` ADD COLUMN `state` int(2) DEFAULT ‘1‘ COMMENT ‘1:未审查,2:已审查‘ ; END IF; IF NOT EXISTS(SELECT column_name FROM INFORMATION_SCHEMA.COLUMNS WHERE column_name=‘transactionidEnd‘ AND table_name=‘ChargeOpAudition‘ AND table_schema=‘ztev_db‘) THEN ALTER TABLE `ChargeOpAudition` ADD COLUMN `transactionidEnd` varchar(100) DEFAULT null COMMENT ‘结束交易号‘ ; END IF; END$$ CALL add_col_homework()$$ drop procedure if exists add_col_homework$$
常写博客,作为笔记
以上是关于spring-boot 在启动运行脚本中执行修改表结构的主要内容,如果未能解决你的问题,请参考以下文章