springboot初始化执行mysql脚本修改库表结构
2021/9/1 19:06:33
本文主要是介绍springboot初始化执行mysql脚本修改库表结构,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
项目启动会执行脚本,修改mysql库表的结构、数据
1.项目每次重启都会执行脚本,修改,添加、删除表、表结构会报错。
2.数据重复新增会报错。
3.数据重复修改导致准确性问题。
解决方案:
1.通过版本来控制,检查数据库中版本和程序中版本是否一致,数据库中版本低时则依次更新每个版本的脚本,最后将数据库中版本号更新。
2.在脚本中刷入存储过程,存储过程中对每一类操作进行定义。给出操作类型和表参数, 检查参数sql是否可执行,然后拼接 sql进行执行。
说明:
方案1的业务逻辑有点复杂。 取resource,解析版本号,正确拆解sql,读取数据库版本后比对……需要一整套的逻辑处理。采用方案2.
实现:
1.借助springboot 的启动执行sql --DataSourceInitializer
@Component public class CustomizeDataSourceInitializer { @Value ("classpath:sql/schema.sql") private Resource dataScript; @Autowired DataSource dataSource; @Bean public DataSourceInitializer dataSourceInitializer( ) { final DataSourceInitializer initializer = new DataSourceInitializer(); // 设置数据源 initializer.setDataSource(dataSource); initializer.setDatabasePopulator(databasePopulator()); return initializer; } private DatabasePopulator databasePopulator() { final ResourceDatabasePopulator populator = new ResourceDatabasePopulator(); //此处修改了分隔符 populator.setSeparator( ScriptUtils.EOF_STATEMENT_SEPARATOR ); populator.addScripts(dataScript); System.out.println("==================sql脚本初始化完成=================="); return populator; } }
2.resource添加脚本sql/schema.sql
------------------------- 中文无法执行 ---------------------------------- DROP PROCEDURE IF EXISTS Pro_Temp_ColumnWork; ^^^ END OF SCRIPT ^^^ -- 1表示新增列,2表示修改列类型,3表示删除列 CREATE PROCEDURE Pro_Temp_ColumnWork(TableName VARCHAR(50),ColumnName VARCHAR(50),SqlStr VARCHAR(4000),CType INT) BEGIN DECLARE Rows1 INT ; SET Rows1=0 ; SELECT COUNT(*) INTO Rows1 FROM INFORMATION_SCHEMA.Columns WHERE table_schema= DATABASE() AND table_name=TableName AND column_name=ColumnName ; -- 新增列 IF (CType=1 AND Rows1<=0) THEN SET SqlStr := CONCAT( 'ALTER TABLE ',TableName,' ADD COLUMN ',ColumnName,' ',SqlStr) ; -- 修改列类型 ELSEIF (CType=2 AND Rows1>0) THEN SET SqlStr := CONCAT('ALTER TABLE ',TableName,' MODIFY ',ColumnName,' ',SqlStr) ; -- 删除列 ELSEIF (CType=3 AND Rows1>0) THEN SET SqlStr := CONCAT('ALTER TABLE ',TableName,' DROP COLUMN ',ColumnName) ; ELSE SET SqlStr :='' ; END IF ; -- 执行命令 IF (SqlStr<>'') THEN SET @SQL1 = SqlStr ; PREPARE stmt1 FROM @SQL1 ; EXECUTE stmt1 ; END IF ; END; ^^^ END OF SCRIPT ^^^ -- alter table gd_device_group modify column device_group_description varchar(255) COMMENT '设备分组描述'; call Pro_Temp_ColumnWork("table_name","colum_name","varchar(255) COMMENT ' testcaaa '",2) ^^^ END OF SCRIPT ^^^
这篇关于springboot初始化执行mysql脚本修改库表结构的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-14折腾之王:JavaScript 之父 Brave 浏览器与 BAT 的诞生
- 2025-01-13从协作到创新:电商团队效率提升新方法
- 2025-01-13汉服销售拓展客源,能精准投放广告的软件求推荐!蛇年新春!
- 2025-01-13提升客户体验的关键:电商团队协作效率优化
- 2025-01-13不触碰资金的支付网关有哪些?
- 2025-01-13如何运用敏捷开发的6大模型来提高团队工作效率?
- 2025-01-13汉服制作质量检测,能高清放大细节的软件用哪个?2025 新春!
- 2025-01-13团队目标管理的6种实用方法(附OKR模板)
- 2025-01-13短剧制片的幕后:如何通过协同编辑提升效率
- 2025-01-13B端产品业务调研:系统步骤与策略解析