开发痛点

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

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

解决之道

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

原理

同步新增的表

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

用到的sql主要有:

show table from rd_db;show create table added_table_name;

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

用到的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();        }

配置

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 

生成效果展示

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

总结

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  3. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  4. android 目录结构,adb环境变量配置
  5. android从服务器下载文件(php+apache+win7+MySql)
  6. Android(安卓)源码结构
  7. Gradle(二) 项目结构
  8. android 系统文件目录结构
  9. Android(安卓)studio 简单的多线程

随机推荐

  1. Android获取在桌面上有图标的app列表的方
  2. Android Camera 模块分析
  3. android CallCard.java/updateState(Phon
  4. android 连接webservice
  5. android 通过百度地图定位获取坐标在导航
  6. android:layout_gravity和android:gravit
  7. Android视图框架
  8. 【Android自学笔记】android实现TextView
  9. Android的地图服务
  10. Android获取在线视频的缩略图方式对比