欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySql開發(fā)之自動同步表結構

 更新時間:2021年05月28日 08:44:16   作者:無毀的湖光-Al  
這篇文章主要給大家介紹了關于MySql開發(fā)之自動同步表結構的相關資料,這樣可以避免在開發(fā)中由于修改數(shù)據(jù)庫字段導致的數(shù)據(jù)庫表不一致問題,需要的朋友可以參考下

開發(fā)痛點

在開發(fā)過程中,由于頻繁的修改數(shù)據(jù)庫的字段,導致rd和qa環(huán)境的數(shù)據(jù)庫表經(jīng)常不一致。

而由于這些修改數(shù)據(jù)庫的操作可能由多個rd操作,很難一次性收集全。人手工去和qa環(huán)境對字段又特別繁瑣,容易遺漏。

解決之道

于是筆者就寫了一個能夠自動比較兩個數(shù)據(jù)庫的表結構,并生成alter語句的程序。同時還可以進行配置從而自動這行這些alter語句。詳情見github

原理

同步新增的表

如果rd環(huán)境新增的表,而qa環(huán)境沒有,此程序可以直接輸出create table語句。原理如下:

用到的sql主要有:

show table from rd_db;
show create table added_table_name;

同步表結構

如果rd表結構有改動,而qa環(huán)境沒有,此程序可以直接輸出alter語句,原理如下:

用到的sql有:

select 
 COLUMN_NAME,COLUMN_TYPE,IS_NULLABLE,COLUMN_DEFAULT,COLUMN_COMMENT,EXTRA 
from 
 information_schema.columns
where 
  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環(huán)境沒有,此程序可以直接輸出修改索引語句。原理和上面類似,在此不再贅述。

配置

sourceHost=127.0.0.1:3306
sourceUser=root
sourcePass=123123123
sourceSchema=mystique_db
sourceCharset=utf8

targetHost=127.0.0.1:3306
targetUser=root
targetPass=123123123
targetSchema=mystique_test
targetCharset=utf8

autoExecute=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_id
alter table mystique_test.t_test_3 add id_2 varchar(50) NULL DEFAULT '' COMMENT '' after name

如果打開了自動執(zhí)行,會自動執(zhí)行這些語句

github鏈接

https://github.com/alchemystar/Lancer

碼云鏈接

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

總結

到此這篇關于MySql開發(fā)之自動同步表結構的文章就介紹到這了,更多相關MySql自動同步表結構內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySQL中使用SQL語句對字段進行重命名

    MySQL中使用SQL語句對字段進行重命名

    MySQL中,如何使用SQL語句來對表中某一個字段進行重命名呢?我們將使用alter table 這一SQL語句,需要的朋友可以參考下
    2016-04-04
  • Mysql DNS反向解析導致連接超時過程分析(skip-name-resolve)

    Mysql DNS反向解析導致連接超時過程分析(skip-name-resolve)

    從其它地方連接MySQL數(shù)據(jù)庫的時候,有時候很慢。慢的原因有可能是MySQL進行反向DNS解析造成的,這里簡單介紹下原理,需要的朋友可以參考下
    2013-03-03
  • mysql 主從復制如何跳過報錯

    mysql 主從復制如何跳過報錯

    這篇文章主要介紹了mysql 主從復制如何跳過報錯,幫助大家更好的理解和使用MySQL 數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-10-10
  • Oracle與MySQL的區(qū)別及優(yōu)缺點

    Oracle與MySQL的區(qū)別及優(yōu)缺點

    這篇文章主要介紹了Oracle與MySQL的區(qū)別及優(yōu)缺點,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參加一下
    2022-08-08
  • mysql 5.7.18 winx64安裝配置方法圖文教程

    mysql 5.7.18 winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了windows7下mysql 5.7.18 winx64安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Mysql sql慢查詢監(jiān)控腳本代碼實例

    Mysql sql慢查詢監(jiān)控腳本代碼實例

    這篇文章主要介紹了Mysql sql慢查詢監(jiān)控腳本代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • 關于MySQL的存儲過程與存儲函數(shù)

    關于MySQL的存儲過程與存儲函數(shù)

    存儲過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL?語句集(這些SQL語句已經(jīng)編譯過了),它存儲在數(shù)據(jù)庫中,一次編譯后永久有效,需要的朋友可以參考下
    2023-05-05
  • mysql中varchar類型的日期進行比較、排序等操作的實現(xiàn)

    mysql中varchar類型的日期進行比較、排序等操作的實現(xiàn)

    在mysql使用過程中,日期一般都是以datetime、timestamp等格式進行存儲的,但有時會因為特殊的需求或歷史原因,日期的存儲格式是varchar,那么應該怎么進行比較和排序等問題,本文就來介紹一下
    2021-11-11
  • mysql-8.0.11-winx64.zip安裝教程詳解

    mysql-8.0.11-winx64.zip安裝教程詳解

    這篇文章主要介紹了mysql-8.0.11-winx64.zip安裝教程詳解及注意事項,非常不錯,具有參考借鑒價值,需要的朋友參考下
    2018-05-05
  • mysql 列轉行的技巧(分享)

    mysql 列轉行的技巧(分享)

    下面小編就為大家?guī)硪黄猰ysql 列轉行的技巧(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03

最新評論