TableGroupServiceImpl.java 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. package org.dbsyncer.biz.impl;
  2. import org.dbsyncer.biz.TableGroupService;
  3. import org.dbsyncer.biz.checker.Checker;
  4. import org.dbsyncer.biz.checker.impl.tablegroup.TableGroupChecker;
  5. import org.dbsyncer.common.util.CollectionUtils;
  6. import org.dbsyncer.common.util.StringUtil;
  7. import org.dbsyncer.connector.model.Field;
  8. import org.dbsyncer.parser.logger.LogType;
  9. import org.dbsyncer.parser.model.Mapping;
  10. import org.dbsyncer.parser.model.TableGroup;
  11. import org.dbsyncer.storage.constant.ConfigConstant;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.stereotype.Service;
  14. import org.springframework.util.Assert;
  15. import java.util.ArrayList;
  16. import java.util.HashSet;
  17. import java.util.List;
  18. import java.util.Map;
  19. import java.util.Set;
  20. import java.util.stream.Stream;
  21. /**
  22. * @author AE86
  23. * @version 1.0.0
  24. * @date 2019/11/27 23:14
  25. */
  26. @Service
  27. public class TableGroupServiceImpl extends BaseServiceImpl implements TableGroupService {
  28. @Autowired
  29. private Checker tableGroupChecker;
  30. @Override
  31. public String add(Map<String, String> params) {
  32. String mappingId = params.get("mappingId");
  33. assertRunning(manager.getMapping(mappingId));
  34. synchronized (LOCK){
  35. // table1, table2
  36. String[] sourceTableArray = StringUtil.split(params.get("sourceTable"), "|");
  37. String[] targetTableArray = StringUtil.split(params.get("targetTable"), "|");
  38. int tableSize = sourceTableArray.length;
  39. Assert.isTrue(tableSize == targetTableArray.length, "数据源表和目标源表关系必须为一组");
  40. String id = null;
  41. for (int i = 0; i < tableSize; i++) {
  42. params.put("sourceTable", sourceTableArray[i]);
  43. params.put("targetTable", targetTableArray[i]);
  44. TableGroup model = (TableGroup) tableGroupChecker.checkAddConfigModel(params);
  45. log(LogType.TableGroupLog.INSERT, model);
  46. int tableGroupCount = manager.getTableGroupCount(mappingId);
  47. model.setIndex(tableGroupCount + 1);
  48. id = manager.addTableGroup(model);
  49. }
  50. // 合并驱动公共字段
  51. mergeMappingColumn(mappingId);
  52. return 1 < tableSize ? String.valueOf(tableSize) : id;
  53. }
  54. }
  55. @Override
  56. public String edit(Map<String, String> params) {
  57. String id = params.get(ConfigConstant.CONFIG_MODEL_ID);
  58. TableGroup tableGroup = manager.getTableGroup(id);
  59. Assert.notNull(tableGroup, "Can not find tableGroup.");
  60. assertRunning(manager.getMapping(tableGroup.getMappingId()));
  61. TableGroup model = (TableGroup) tableGroupChecker.checkEditConfigModel(params);
  62. log(LogType.TableGroupLog.UPDATE, model);
  63. return manager.editTableGroup(model);
  64. }
  65. @Override
  66. public String refreshFields(String id) {
  67. TableGroup tableGroup = manager.getTableGroup(id);
  68. Assert.notNull(tableGroup, "Can not find tableGroup.");
  69. assertRunning(manager.getMapping(tableGroup.getMappingId()));
  70. TableGroupChecker checker = (TableGroupChecker) tableGroupChecker;
  71. checker.refreshTableFields(tableGroup);
  72. return manager.editTableGroup(tableGroup);
  73. }
  74. @Override
  75. public boolean remove(String mappingId, String ids) {
  76. Assert.hasText(mappingId, "Mapping id can not be null");
  77. Assert.hasText(ids, "TableGroup ids can not be null");
  78. assertRunning(manager.getMapping(mappingId));
  79. // 批量删除表
  80. Stream.of(StringUtil.split(ids, ",")).parallel().forEach(id -> {
  81. TableGroup model = manager.getTableGroup(id);
  82. log(LogType.TableGroupLog.DELETE, model);
  83. manager.removeConfigModel(id);
  84. });
  85. // 合并驱动公共字段
  86. mergeMappingColumn(mappingId);
  87. // 重置排序
  88. resetTableGroupAllIndex(mappingId);
  89. return true;
  90. }
  91. @Override
  92. public TableGroup getTableGroup(String id) {
  93. TableGroup tableGroup = manager.getTableGroup(id);
  94. Assert.notNull(tableGroup, "TableGroup can not be null");
  95. return tableGroup;
  96. }
  97. @Override
  98. public List<TableGroup> getTableGroupAll(String mappingId) {
  99. return manager.getSortedTableGroupAll(mappingId);
  100. }
  101. private void resetTableGroupAllIndex(String mappingId) {
  102. synchronized (LOCK) {
  103. List<TableGroup> list = manager.getSortedTableGroupAll(mappingId);
  104. int size = list.size();
  105. int i = size;
  106. while (i > 0) {
  107. TableGroup g = list.get(size - i);
  108. g.setIndex(i);
  109. manager.editConfigModel(g);
  110. i--;
  111. }
  112. }
  113. }
  114. private void mergeMappingColumn(String mappingId) {
  115. List<TableGroup> groups = manager.getTableGroupAll(mappingId);
  116. Mapping mapping = manager.getMapping(mappingId);
  117. Assert.notNull(mapping, "mapping not exist.");
  118. List<Field> sourceColumn = null;
  119. List<Field> targetColumn = null;
  120. for (TableGroup g : groups) {
  121. sourceColumn = pickCommonFields(sourceColumn, g.getSourceTable().getColumn());
  122. targetColumn = pickCommonFields(targetColumn, g.getTargetTable().getColumn());
  123. }
  124. mapping.setSourceColumn(sourceColumn);
  125. mapping.setTargetColumn(targetColumn);
  126. manager.editConfigModel(mapping);
  127. }
  128. private List<Field> pickCommonFields(List<Field> column, List<Field> target) {
  129. if (CollectionUtils.isEmpty(column) || CollectionUtils.isEmpty(target)) {
  130. return target;
  131. }
  132. List<Field> list = new ArrayList<>();
  133. Set<String> keys = new HashSet<>();
  134. column.forEach(f -> keys.add(f.getName()));
  135. target.forEach(f -> {
  136. if (keys.contains(f.getName())) {
  137. list.add(f);
  138. }
  139. });
  140. return list;
  141. }
  142. }