TableGroupServiceImpl.java 4.9 KB

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