package io.mycat.route.parser.druid; import io.mycat.sqlengine.mpp.ColumnRoutePair; import io.mycat.sqlengine.mpp.RangeValue; import java.util.LinkedHashMap; import java.util.LinkedHashSet; import java.util.Map; import java.util.Set; /** * 路由计算单元 * * @author wang.dw * @date 2015-3-14 下午6:24:54 * @version 0.1.0 * @copyright wonhigh.cn */ public class RouteCalculateUnit { private Map<String, Map<String, Set<ColumnRoutePair>>> tablesAndConditions = new LinkedHashMap<String, Map<String, Set<ColumnRoutePair>>>(); public Map<String, Map<String, Set<ColumnRoutePair>>> getTablesAndConditions() { return tablesAndConditions; } public void addShardingExpr(String tableName, String columnName, Object value) { Map<String, Set<ColumnRoutePair>> tableColumnsMap = tablesAndConditions.get(tableName); if (value == null) { // where a=null return; } if (tableColumnsMap == null) { tableColumnsMap = new LinkedHashMap<String, Set<ColumnRoutePair>>(); tablesAndConditions.put(tableName, tableColumnsMap); } String uperColName = columnName.toUpperCase(); Set<ColumnRoutePair> columValues = tableColumnsMap.get(uperColName); if (columValues == null) { columValues = new LinkedHashSet<ColumnRoutePair>(); tablesAndConditions.get(tableName).put(uperColName, columValues); } if (value instanceof Object[]) { for (Object item : (Object[]) value) { if(item == null) { continue; } columValues.add(new ColumnRoutePair(item.toString())); } } else if (value instanceof RangeValue) { columValues.add(new ColumnRoutePair((RangeValue) value)); } else { columValues.add(new ColumnRoutePair(value.toString())); } } public void clear() { tablesAndConditions.clear(); } }