123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- package org.dbsyncer.biz.impl;
- import org.dbsyncer.biz.TableGroupService;
- import org.dbsyncer.biz.checker.Checker;
- import org.dbsyncer.common.util.CollectionUtils;
- import org.dbsyncer.common.util.StringUtil;
- import org.dbsyncer.connector.model.Field;
- import org.dbsyncer.parser.logger.LogType;
- import org.dbsyncer.parser.model.Mapping;
- import org.dbsyncer.parser.model.TableGroup;
- import org.dbsyncer.storage.constant.ConfigConstant;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.util.Assert;
- import java.util.*;
- import java.util.stream.Stream;
- /**
- * @author AE86
- * @version 1.0.0
- * @date 2019/11/27 23:14
- */
- @Service
- public class TableGroupServiceImpl extends BaseServiceImpl implements TableGroupService {
- private final Logger logger = LoggerFactory.getLogger(getClass());
- @Autowired
- private Checker tableGroupChecker;
- @Override
- public String add(Map<String, String> params) {
- String mappingId = params.get("mappingId");
- assertRunning(manager.getMapping(mappingId));
- // table1, table2
- String[] sourceTableArray = StringUtil.split(params.get("sourceTable"), "|");
- String[] targetTableArray = StringUtil.split(params.get("targetTable"), "|");
- int tableSize = sourceTableArray.length;
- Assert.isTrue(tableSize == targetTableArray.length, "数据源表和目标源表关系必须为一组");
- String id = null;
- for (int i = 0; i < tableSize; i++) {
- params.put("sourceTable", sourceTableArray[i]);
- params.put("targetTable", targetTableArray[i]);
- TableGroup model = (TableGroup) tableGroupChecker.checkAddConfigModel(params);
- log(LogType.TableGroupLog.INSERT, model);
- id = manager.addTableGroup(model);
- }
- // 合并驱动公共字段
- mergeMappingColumn(mappingId);
- return 1 < tableSize ? String.valueOf(tableSize) : id;
- }
- @Override
- public String edit(Map<String, String> params) {
- String id = params.get(ConfigConstant.CONFIG_MODEL_ID);
- TableGroup tableGroup = manager.getTableGroup(id);
- Assert.notNull(tableGroup, "Can not find tableGroup.");
- assertRunning(manager.getMapping(tableGroup.getMappingId()));
- TableGroup model = (TableGroup) tableGroupChecker.checkEditConfigModel(params);
- log(LogType.TableGroupLog.UPDATE, model);
- return manager.editTableGroup(model);
- }
- @Override
- public boolean remove(String mappingId, String ids) {
- Assert.hasText(mappingId, "Mapping id can not be null");
- Assert.hasText(ids, "TableGroup ids can not be null");
- assertRunning(manager.getMapping(mappingId));
- // 批量删除表
- Stream.of(StringUtil.split(ids, ",")).parallel().forEach(id -> {
- TableGroup model = manager.getTableGroup(id);
- log(LogType.TableGroupLog.DELETE, model);
- manager.removeTableGroup(id);
- });
- // 合并驱动公共字段
- mergeMappingColumn(mappingId);
- return true;
- }
- @Override
- public TableGroup getTableGroup(String id) {
- TableGroup tableGroup = manager.getTableGroup(id);
- Assert.notNull(tableGroup, "TableGroup can not be null");
- return tableGroup;
- }
- @Override
- public List<TableGroup> getTableGroupAll(String mappingId) {
- return manager.getTableGroupAll(mappingId);
- }
- private void mergeMappingColumn(String mappingId) {
- List<TableGroup> groups = manager.getTableGroupAll(mappingId);
- Mapping mapping = manager.getMapping(mappingId);
- Assert.notNull(mapping, "mapping not exist.");
- List<Field> sourceColumn = null;
- List<Field> targetColumn = null;
- for (TableGroup g : groups) {
- sourceColumn = pickCommonFields(sourceColumn, g.getSourceTable().getColumn());
- targetColumn = pickCommonFields(targetColumn, g.getTargetTable().getColumn());
- }
- mapping.setSourceColumn(sourceColumn);
- mapping.setTargetColumn(targetColumn);
- manager.editMapping(mapping);
- }
- private List<Field> pickCommonFields(List<Field> column, List<Field> target) {
- if (CollectionUtils.isEmpty(column) || CollectionUtils.isEmpty(target)) {
- return target;
- }
- List<Field> list = new ArrayList<>();
- Set<String> keys = new HashSet<>();
- column.forEach(f -> keys.add(f.getName()));
- target.forEach(f -> {
- if (keys.contains(f.getName())) {
- list.add(f);
- }
- });
- return list;
- }
- }
|