You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@shardingsphere.apache.org by du...@apache.org on 2022/04/27 08:31:10 UTC
[shardingsphere] branch master updated: add pipeline ddl generator. (#17147)
This is an automated email from the ASF dual-hosted git repository.
duanzhengqiang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/shardingsphere.git
The following commit(s) were added to refs/heads/master by this push:
new 4b2beeef309 add pipeline ddl generator. (#17147)
4b2beeef309 is described below
commit 4b2beeef3097ba82cee6b4516a09206cf049cee7
Author: Chuxin Chen <ch...@qq.com>
AuthorDate: Wed Apr 27 16:31:01 2022 +0800
add pipeline ddl generator. (#17147)
---
.../metadata/generator/PipelineDDLGenerator.java | 96 ++++++++++++++++++++++
1 file changed, 96 insertions(+)
diff --git a/shardingsphere-kernel/shardingsphere-data-pipeline/shardingsphere-data-pipeline-core/src/main/java/org/apache/shardingsphere/data/pipeline/core/metadata/generator/PipelineDDLGenerator.java b/shardingsphere-kernel/shardingsphere-data-pipeline/shardingsphere-data-pipeline-core/src/main/java/org/apache/shardingsphere/data/pipeline/core/metadata/generator/PipelineDDLGenerator.java
new file mode 100644
index 00000000000..9b696e15935
--- /dev/null
+++ b/shardingsphere-kernel/shardingsphere-data-pipeline/shardingsphere-data-pipeline-core/src/main/java/org/apache/shardingsphere/data/pipeline/core/metadata/generator/PipelineDDLGenerator.java
@@ -0,0 +1,96 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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 org.apache.shardingsphere.data.pipeline.core.metadata.generator;
+
+import com.google.common.base.Preconditions;
+import lombok.RequiredArgsConstructor;
+import org.apache.shardingsphere.infra.binder.LogicSQL;
+import org.apache.shardingsphere.infra.binder.SQLStatementContextFactory;
+import org.apache.shardingsphere.infra.binder.statement.SQLStatementContext;
+import org.apache.shardingsphere.infra.database.type.DatabaseType;
+import org.apache.shardingsphere.infra.metadata.ShardingSphereMetaData;
+import org.apache.shardingsphere.infra.parser.ShardingSphereSQLParserEngine;
+import org.apache.shardingsphere.infra.rewrite.SQLRewriteEntry;
+import org.apache.shardingsphere.infra.rewrite.engine.result.RouteSQLRewriteResult;
+import org.apache.shardingsphere.infra.rewrite.engine.result.SQLRewriteResult;
+import org.apache.shardingsphere.infra.route.context.RouteContext;
+import org.apache.shardingsphere.infra.route.context.RouteMapper;
+import org.apache.shardingsphere.infra.route.context.RouteUnit;
+import org.apache.shardingsphere.mode.manager.ContextManager;
+import org.apache.shardingsphere.parser.rule.SQLParserRule;
+import org.apache.shardingsphere.sql.parser.sql.common.statement.SQLStatement;
+
+import java.util.Collection;
+import java.util.Collections;
+import java.util.LinkedList;
+import java.util.Optional;
+
+/**
+ * Pipeline ddl generator.
+ */
+@RequiredArgsConstructor
+public final class PipelineDDLGenerator {
+
+ private final ContextManager contextManager;
+
+ /**
+ * Replace table name with prefix.
+ *
+ * @param sql sql
+ * @param prefix prefix
+ * @param databaseType database type
+ * @param databaseName database name
+ * @return replaced sql
+ */
+ public String replaceTableNameWithPrefix(final String sql, final String prefix, final DatabaseType databaseType, final String databaseName) {
+ LogicSQL logicSQL = getLogicSQL(sql, databaseType, databaseName);
+ RouteContext routeContext = getRouteContext(prefix, logicSQL);
+ return getRewriteSQL(sql, databaseName, logicSQL, routeContext);
+ }
+
+ private String getRewriteSQL(final String sql, final String databaseName, final LogicSQL logicSQL, final RouteContext routeContext) {
+ ShardingSphereMetaData metaData = contextManager.getMetaDataContexts().getMetaData(databaseName);
+ SQLRewriteEntry rewriteEntry = new SQLRewriteEntry(metaData.getDatabaseName(), metaData.getSchemas(), contextManager.getMetaDataContexts().getProps(), metaData.getRuleMetaData().getRules());
+ SQLRewriteResult sqlRewriteResult = rewriteEntry.rewrite(logicSQL.getSql(), logicSQL.getParameters(), logicSQL.getSqlStatementContext(), routeContext);
+ if (sqlRewriteResult instanceof RouteSQLRewriteResult) {
+ return ((RouteSQLRewriteResult) sqlRewriteResult).getSqlRewriteUnits().get(routeContext.getRouteUnits().iterator().next()).getSql();
+ }
+ return sql;
+ }
+
+ private RouteContext getRouteContext(final String prefix, final LogicSQL logicSQL) {
+ Collection<String> tableNames = logicSQL.getSqlStatementContext().getTablesContext().getTableNames();
+ RouteContext result = new RouteContext();
+ Collection<RouteMapper> tableMappers = new LinkedList<>();
+ for (String each : tableNames) {
+ tableMappers.add(new RouteMapper(each, prefix + each));
+ }
+ RouteUnit routeUnit = new RouteUnit(new RouteMapper("", ""), tableMappers);
+ result.getRouteUnits().add(routeUnit);
+ return result;
+ }
+
+ private LogicSQL getLogicSQL(final String sql, final DatabaseType databaseType, final String databaseName) {
+ Optional<SQLParserRule> sqlParserRule = contextManager.getMetaDataContexts().getGlobalRuleMetaData().findSingleRule(SQLParserRule.class);
+ Preconditions.checkState(sqlParserRule.isPresent());
+ SQLStatement sqlStatement = new ShardingSphereSQLParserEngine(databaseType.getName(), sqlParserRule.get().toParserConfiguration()).parse(sql, false);
+ SQLStatementContext<?> sqlStatementContext = SQLStatementContextFactory.newInstance(contextManager.getMetaDataContexts().getMetaDataMap(),
+ sqlStatement, databaseName);
+ return new LogicSQL(sqlStatementContext, sql, Collections.emptyList());
+ }
+}