当前位置:Gxlcms > 数据库问题 > Mysql根据一个基库生成其他库与其不同的库升级脚本

Mysql根据一个基库生成其他库与其不同的库升级脚本

时间:2021-07-01 10:21:17 帮助过:13人阅读

今天研究了一下不同数据库之间如何做同步。弄了一个升级工具类,希望以后还能有所帮助。

 

  1. public class UpgradeDataBase {
  2. public static void main(String[] args) {
  3. //两个不同数据库名称
  4. List<String> sqls = UpgradeDataBaseToStandardDataBase("database1", "database2");
  5. for(String sql : sqls) {
  6. System.out.println(sql);
  7. }
  8. }
  9. /**
  10. * 将基准库里有的表字段,以名称为基准,生成同步到目标库中的脚本
  11. */
  12. public static List<String> UpgradeDataBaseToStandardDataBase(String standard, String target) {
  13. List<String> upgradeSqls = new ArrayList<>();
  14. List<String> standardTables = new ArrayList<>();
  15. List<String> targetTables = new ArrayList<>();
  16. Connection connStandard = null;
  17. Connection connTarget = null;
  18. Statement stmtStandard = null;
  19. Statement stmtTarget = null;
  20. ResultSet rsStandard = null;
  21. ResultSet rsTarget = null;
  22. try {
  23. Properties props = Resources.getResourceAsProperties("jdbc.properties");
  24. String url = props.getProperty("url");
  25. String driver = props.getProperty("driver");
  26. String username = props.getProperty("username");
  27. String password = props.getProperty("password");
  28. Class.forName(driver).newInstance();
  29. //拿到2个库的链接
  30. connStandard = DriverManager.getConnection(url, username, password);
  31. connStandard.setCatalog(standard);
  32. connTarget = DriverManager.getConnection(url, username, password);
  33. connTarget.setCatalog(target);
  34. stmtStandard = connStandard.createStatement();
  35. stmtTarget = connTarget.createStatement();
  36. //先把2个库所有的表查出来
  37. stmtStandard.execute("show tables");
  38. stmtTarget.execute("show tables");
  39. rsStandard = stmtStandard.getResultSet();
  40. rsTarget = stmtTarget.getResultSet();
  41. while (rsStandard.next()){
  42. standardTables.add(rsStandard.getString(1));
  43. }
  44. while (rsTarget.next()){
  45. targetTables.add(rsTarget.getString(1));
  46. }
  47. //循环基准库中每一张表
  48. for(String table : standardTables) {
  49. if("SM_USER".equals(table)) {
  50. continue;
  51. }
  52. if(targetTables.contains(table)) {
  53. Map<String, Map<String, String>> standardColumns = new HashMap<>();
  54. Map<String, Map<String, String>> targetColumns = new HashMap<>();
  55. //检查每一个字段,
  56. //1.首先先查出目标库和基准库该表的所有字段
  57. stmtStandard.execute("show columns from " + table + " from " + standard);
  58. rsStandard = stmtStandard.getResultSet();
  59. while (rsStandard.next()){
  60. Map<String, String> map = new HashMap<>();
  61. map.put("Field", rsStandard.getString("Field"));//列名
  62. map.put("Type", rsStandard.getString("Type"));//类型+长度
  63. map.put("Null", rsStandard.getString("Null"));//是否可为空
  64. map.put("Key", rsStandard.getString("Key"));//是否主键
  65. map.put("Default", rsStandard.getString("Default"));//默认值
  66. map.put("Extra", rsStandard.getString("Extra"));//其他(自增列,触发器等)
  67. standardColumns.put(rsStandard.getString("Field"), map);
  68. }
  69. stmtTarget.execute("show columns from " + table + " from " + target);
  70. rsTarget = stmtTarget.getResultSet();
  71. while (rsTarget.next()){
  72. Map<String, String> map = new HashMap<>();
  73. map.put("Field", rsTarget.getString("Field"));//列名
  74. map.put("Type", rsTarget.getString("Type"));//类型+长度
  75. map.put("Null", rsTarget.getString("Null"));//是否可为空
  76. map.put("Key", rsTarget.getString("Key"));//是否主键
  77. map.put("Default", rsTarget.getString("Default"));//默认值
  78. map.put("Extra", rsTarget.getString("Extra"));//其他(自增列,触发器等)
  79. targetColumns.put(rsTarget.getString("Field"), map);
  80. }
  81. //2.以基准库为准,逐个列比较
  82. //TODO 没有处理Key(没有做主键、自增处理)
  83. for(String column : standardColumns.keySet()) {
  84. if(targetColumns.containsKey(column)) {//存在这一列
  85. boolean needGeneSql = false;
  86. StringBuffer buffer = new StringBuffer();
  87. //类型有变化, 但是不管类型有没有变化,后续的语句都需要
  88. // if(standardColumns.get(column).get("Type") != null && !standardColumns.get(column).get("Type").equals(targetColumns.get(column).get("Type"))) {
  89. // buffer.append(standardColumns.get(column).get("Type"));
  90. // }
  91. buffer.append(standardColumns.get(column).get("Type"));
  92. //默认值有变
  93. if(standardColumns.get(column).get("Default") != null && !standardColumns.get(column).get("Default").equals(targetColumns.get(column).get("Default"))) {
  94. buffer.append(" default " + standardColumns.get(column).get("Default"));
  95. needGeneSql = true;
  96. }
  97. //是否可空有变
  98. if(standardColumns.get(column).get("Null") != null && !standardColumns.get(column).get("Null").equals(targetColumns.get(column).get("Null"))) {
  99. buffer.append(("NO".equals(standardColumns.get(column).get("Null")) ? " not null " : " null "));
  100. needGeneSql = true;
  101. }
  102. //处理自增长等
  103. if(standardColumns.get(column).get("Extra") != null && !standardColumns.get(column).get("Extra").equals(targetColumns.get(column).get("Extra"))) {
  104. buffer.append(" ").append(standardColumns.get(column).get("Extra"));
  105. needGeneSql = true;
  106. }
  107. if(needGeneSql) {
  108. String changeColumnSql = "alter table " + table + " change " + column + " " + column + " " + buffer.toString() + ";";
  109. upgradeSqls.add(changeColumnSql);
  110. }
  111. }
  112. else{
  113. String addColumnSql = "alter table " + table +
  114. " add column " + column + " " +
  115. standardColumns.get(column).get("Type") + " default " + standardColumns.get(column).get("Default") +
  116. ("NO".equals(standardColumns.get(column).get("Null")) ? " not null " : " null ") + ";";
  117. upgradeSqls.add(addColumnSql);
  118. }
  119. }
  120. }
  121. else{//目标库中,没有基准库的表
  122. stmtStandard.execute("show create table " + table);
  123. rsStandard = stmtStandard.getResultSet();
  124. String createSql = null;
  125. while (rsStandard.next()){
  126. //第2列是建表语句
  127. createSql = rsStandard.getString(2);
  128. upgradeSqls.add(createSql + ";");
  129. }
  130. }
  131. }
  132. } catch (Exception e) {
  133. e.printStackTrace();
  134. } finally {
  135. try {
  136. rsStandard.close();
  137. rsTarget.close();
  138. stmtStandard.close();
  139. stmtTarget.close();
  140. connStandard.close();
  141. connTarget.close();
  142. } catch (SQLException e) {
  143. e.printStackTrace();
  144. }
  145. }
  146. return upgradeSqls;
  147. }
  148. }

  

  

Mysql根据一个基库生成其他库与其不同的库升级脚本

标签:new   stat   connect   检查   show   脚本   url   cut   oid   

人气教程排行