All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.shardingsphere.core.rule.TableRule Maven / Gradle / Ivy

There is a newer version: 3.1.0
Show newest version
/*
 * Copyright 2016-2018 shardingsphere.io.
 * 

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *

*/ package io.shardingsphere.core.rule; import com.google.common.base.Preconditions; import io.shardingsphere.api.config.TableRuleConfiguration; import io.shardingsphere.core.exception.ShardingException; import io.shardingsphere.core.keygen.KeyGenerator; import io.shardingsphere.core.routing.strategy.ShardingStrategy; import io.shardingsphere.core.routing.strategy.ShardingStrategyFactory; import io.shardingsphere.core.util.InlineExpressionParser; import lombok.AccessLevel; import lombok.Getter; import lombok.ToString; import java.util.Collection; import java.util.Collections; import java.util.HashMap; import java.util.LinkedHashMap; import java.util.LinkedHashSet; import java.util.LinkedList; import java.util.List; import java.util.Map; /** * Table rule configuration. * * @author zhangliang */ @Getter @ToString(exclude = "dataNodeIndexMap") public final class TableRule { private final String logicTable; private final List actualDataNodes; @Getter(AccessLevel.NONE) private final Map dataNodeIndexMap; private final ShardingStrategy databaseShardingStrategy; private final ShardingStrategy tableShardingStrategy; private final String generateKeyColumn; private final KeyGenerator keyGenerator; private final String logicIndex; public TableRule(final String defaultDataSourceName, final String logicTableName) { logicTable = logicTableName.toLowerCase(); actualDataNodes = Collections.singletonList(new DataNode(defaultDataSourceName, logicTableName)); dataNodeIndexMap = Collections.emptyMap(); databaseShardingStrategy = null; tableShardingStrategy = null; generateKeyColumn = null; keyGenerator = null; logicIndex = null; } public TableRule(final TableRuleConfiguration tableRuleConfig, final ShardingDataSourceNames shardingDataSourceNames) { Preconditions.checkNotNull(tableRuleConfig.getLogicTable(), "Logic table cannot be null."); logicTable = tableRuleConfig.getLogicTable().toLowerCase(); List dataNodes = new InlineExpressionParser(tableRuleConfig.getActualDataNodes()).splitAndEvaluate(); dataNodeIndexMap = new HashMap<>(dataNodes.size(), 1); actualDataNodes = isEmptyDataNodes(dataNodes) ? generateDataNodes(tableRuleConfig.getLogicTable(), shardingDataSourceNames.getDataSourceNames()) : generateDataNodes(dataNodes, shardingDataSourceNames.getDataSourceNames()); databaseShardingStrategy = null == tableRuleConfig.getDatabaseShardingStrategyConfig() ? null : ShardingStrategyFactory.newInstance(tableRuleConfig.getDatabaseShardingStrategyConfig()); tableShardingStrategy = null == tableRuleConfig.getTableShardingStrategyConfig() ? null : ShardingStrategyFactory.newInstance(tableRuleConfig.getTableShardingStrategyConfig()); generateKeyColumn = tableRuleConfig.getKeyGeneratorColumnName(); keyGenerator = tableRuleConfig.getKeyGenerator(); logicIndex = null == tableRuleConfig.getLogicIndex() ? null : tableRuleConfig.getLogicIndex().toLowerCase(); } private boolean isEmptyDataNodes(final List dataNodes) { return null == dataNodes || dataNodes.isEmpty(); } private List generateDataNodes(final String logicTable, final Collection dataSourceNames) { List result = new LinkedList<>(); int index = 0; for (String each : dataSourceNames) { DataNode dataNode = new DataNode(each, logicTable); result.add(dataNode); dataNodeIndexMap.put(dataNode, index); index++; } return result; } private List generateDataNodes(final List actualDataNodes, final Collection dataSourceNames) { List result = new LinkedList<>(); int index = 0; for (String each : actualDataNodes) { DataNode dataNode = new DataNode(each); if (!dataSourceNames.contains(dataNode.getDataSourceName())) { throw new ShardingException("Cannot find data source in sharding rule, invalid actual data node is: '%s'", each); } result.add(dataNode); dataNodeIndexMap.put(dataNode, index); index++; } return result; } /** * Get data node groups. * * @return data node groups, key is data source name, value is tables belong to this data source */ public Map> getDataNodeGroups() { Map> result = new LinkedHashMap<>(actualDataNodes.size(), 1); for (DataNode each : actualDataNodes) { String dataSourceName = each.getDataSourceName(); if (!result.containsKey(dataSourceName)) { result.put(dataSourceName, new LinkedList()); } result.get(dataSourceName).add(each); } return result; } /** * Get actual data source names. * * @return actual data source names */ public Collection getActualDatasourceNames() { Collection result = new LinkedHashSet<>(actualDataNodes.size()); for (DataNode each : actualDataNodes) { result.add(each.getDataSourceName()); } return result; } /** * Get actual table names via target data source name. * * @param targetDataSource target data source name * @return names of actual tables */ public Collection getActualTableNames(final String targetDataSource) { Collection result = new LinkedHashSet<>(actualDataNodes.size()); for (DataNode each : actualDataNodes) { if (targetDataSource.equals(each.getDataSourceName())) { result.add(each.getTableName()); } } return result; } int findActualTableIndex(final String dataSourceName, final String actualTableName) { DataNode dataNode = new DataNode(dataSourceName, actualTableName); return dataNodeIndexMap.containsKey(dataNode) ? dataNodeIndexMap.get(dataNode) : -1; } boolean isExisted(final String actualTableName) { for (DataNode each : actualDataNodes) { if (each.getTableName().equalsIgnoreCase(actualTableName)) { return true; } } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy