TableGroupServiceImpl.java 4.7 KB

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