gpt4 book ai didi

MySql开发之自动同步表结构

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章MySql开发之自动同步表结构由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

开发痛点

  。

在开发过程中,由于频繁的修改数据库的字段,导致rd和qa环境的数据库表经常不一致.

而由于这些修改数据库的操作可能由多个rd操作,很难一次性收集全。人手工去和qa环境对字段又特别繁琐,容易遗漏.

解决之道

  。

于是笔者就写了一个能够自动比较两个数据库的表结构,并生成alter语句的程序。同时还可以进行配置从而自动这行这些alter语句。详情见github 。

原理

  。

同步新增的表 。

如果rd环境新增的表,而qa环境没有,此程序可以直接输出create table语句。原理如下

MySql开发之自动同步表结构

用到的sql主要有

show table from rd_db;show create table added_table_name;

同步表结构 。

如果rd表结构有改动,而qa环境没有,此程序可以直接输出alter语句,原理如下

MySql开发之自动同步表结构

用到的sql有

select  COLUMN_NAME,COLUMN_TYPE,IS_NULLABLE,COLUMN_DEFAULT,COLUMN_COMMENT,EXTRA from  information_schema.columnswhere   TABLE_SCHEMA="rd_db"  and TABLE_NAME = "rd_table";

比较表结构的代码

        for (Column column : sourceTable.getColumns().values()) {            if (targetTable.getColumns().get(column.getName()) == null) {                // 如果对应的target没有这个字段,直接alter                String sql = "alter table " + target.getSchema() + "." + targetTable.getTableName() + " add " + column                        .getName() + " ";                sql += column.getType() + " ";                if (column.getIsNull().equals("NO")) {                    sql += "NOT NULL ";                } else {                    sql += "NULL ";                }                if (column.getDefaultValue() != null) {                    sql += "DEFAULT " + SqlUtil.getDbString(column.getDefaultValue()) + " ";                }                if (column.getComment() != null) {                    sql += "COMMENT " + SqlUtil.getDbString(column.getComment()) + " ";                }                if (after != null) {                    sql += "after " + after;                }                changeSql.add(sql+";");            } else {                // 检查对应的source 和 target的属性                String sql =                        "alter table " + target.getSchema() + "." + targetTable.getTableName() + " change " + column                                .getName() + " ";                Column sourceColumn = column;                Column targetColumn = targetTable.getColumns().get(sourceColumn.getName());                // 比较两者字段,如果返回null,表明一致                String sqlExtend = compareSingleColumn(sourceColumn, targetColumn);                if (sqlExtend != null) {                    changeSql.add(sql + sqlExtend+";");                }            }            after = column.getName();        }

同步索引结构

  。

如果rd表的索引有改变,而qa环境没有,此程序可以直接输出修改索引语句。原理和上面类似,在此不再赘述.

配置 。

sourceHost=127.0.0.1:3306sourceUser=rootsourcePass=123123123sourceSchema=mystique_dbsourceCharset=utf8targetHost=127.0.0.1:3306targetUser=roottargetPass=123123123targetSchema=mystique_testtargetCharset=utf8autoExecute=YES //此处表明自动同步

运行 。

按照上面的模板进行配置 用IDE打开,找到 。

alchemystar.runner.ShellRunner 

运行其中的main方法即可 。

生成效果展示 。

alter table mystique_test.t_test_3 change id id bigint(20) NOT NULL AUTO_INCREMENT COMMENT ""alter table mystique_test.t_test_3 add index (name)alter table mystique_test.t_test_3 drop index name_idalter table mystique_test.t_test_3 add id_2 varchar(50) NULL DEFAULT "" COMMENT "" after name

如果打开了自动执行,会自动执行这些语句 。

github链接 。

https://github.com/alchemystar/Lancer 。

码云链接 。

https://git.oschina.net/alchemystar/Lancer 。

总结

  。

到此这篇关于MySql开发之自动同步表结构的文章就介绍到这了,更多相关MySql自动同步表结构内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://my.oschina.net/alchemystar/blog/858996 。

最后此篇关于MySql开发之自动同步表结构的文章就讲到这里了,如果你想了解更多关于MySql开发之自动同步表结构的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com