From 972411d9f41da6d0e101f53e9d22e1be41349bd1 Mon Sep 17 00:00:00 2001 From: zaiyuan49 Date: Tue, 9 Aug 2022 20:02:30 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=20drop=20index=20?= =?UTF-8?q?=E5=86=85=E5=AE=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../apache/calcite/sql/ddl/SqlDropIndex.java | 90 +++++++++++++++++++ .../db/parser/visitor/StartDBVisitor.scala | 1 + .../start/db/executor/DropIndexExecutor.scala | 36 ++++++++ 3 files changed, 127 insertions(+) create mode 100644 start-db-calcite/src/main/java/org/apache/calcite/sql/ddl/SqlDropIndex.java create mode 100644 start-db-core/src/main/scala/org/urbcomp/start/db/executor/DropIndexExecutor.scala diff --git a/start-db-calcite/src/main/java/org/apache/calcite/sql/ddl/SqlDropIndex.java b/start-db-calcite/src/main/java/org/apache/calcite/sql/ddl/SqlDropIndex.java new file mode 100644 index 00000000..e00139b4 --- /dev/null +++ b/start-db-calcite/src/main/java/org/apache/calcite/sql/ddl/SqlDropIndex.java @@ -0,0 +1,90 @@ +/* + * This file is inherited from Apache Calcite and modifed by ST-Lab under apache license. + * You can find the original code from + * + * https://github.com/apache/calcite + * + * 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.calcite.sql.ddl; + +import org.apache.calcite.sql.*; +import org.apache.calcite.sql.parser.SqlParserPos; +import org.urbcomp.start.db.util.StringUtil; + +import javax.annotation.Nonnull; +import java.util.ArrayList; +import java.util.List; + +public class SqlDropIndex extends SqlDdl { + + private String indexName; + + /** + * 表名 + */ + private SqlIdentifier relation; + + /** + * 构造方法 + * + * @param operator 操作类型 + * @param pos 解析位置 + */ + public SqlDropIndex(SqlOperator operator, SqlParserPos pos) { + super(operator, pos); + } + + public SqlDropIndex(SqlParserPos pos, String indexName, SqlIdentifier relation) { + this(new SqlSpecialOperator("DROP INDEX", SqlKind.DROP_INDEX), pos); + this.indexName = StringUtil.dropQuota(indexName); + this.relation = relation; + } + + @Nonnull + @Override + public List getOperandList() { + return new ArrayList<>(); + } + + public String getIndexName() { + return indexName; + } + + public void setIndexName(String indexName) { + this.indexName = indexName; + } + + public SqlIdentifier getRelation() { + return relation; + } + + public void setRelation(SqlIdentifier relation) { + this.relation = relation; + } + + @Override + public String toString() { + return "SqlDropTableIndex{" + + "indexName='" + + indexName + + '\'' + + ", relation=" + + relation + + '}'; + } +} diff --git a/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala b/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala index b493773f..7bdb53ce 100644 --- a/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala +++ b/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala @@ -190,6 +190,7 @@ class StartDBVisitor(user: String, db: String) extends StartDBSqlBaseVisitor[Any } def getKeyWord(list: SelectListContext): SqlNodeList = { + c if (list.selectListSet() == null) null else { val context = list.selectListSet() diff --git a/start-db-core/src/main/scala/org/urbcomp/start/db/executor/DropIndexExecutor.scala b/start-db-core/src/main/scala/org/urbcomp/start/db/executor/DropIndexExecutor.scala new file mode 100644 index 00000000..c6d3dafb --- /dev/null +++ b/start-db-core/src/main/scala/org/urbcomp/start/db/executor/DropIndexExecutor.scala @@ -0,0 +1,36 @@ +/* + * Copyright 2022 ST-Lab + * + * This program is free software; you can redistribute it and/or modify it under the terms of the + * GNU General Public License version 2 as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without + * even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + */ + +package org.urbcomp.start.db.executor + +import org.apache.calcite.sql.ddl.SqlDropIndex +import org.urbcomp.start.db.executor.utils.ExecutorUtil +import org.urbcomp.start.db.infra.{BaseExecutor, MetadataResult} +import org.urbcomp.start.db.metadata.MetadataAccessUtil +import org.urbcomp.start.db.util.SqlParam + +case class DropIndexExecutor(node: SqlDropIndex) extends BaseExecutor { + + override def execute[Int](): MetadataResult[Int] = { + val param = SqlParam.CACHE.get() + val targetTable = node.getRelation + val (userName, dbName, tableName) = ExecutorUtil.getUserNameDbNameAndTableName(targetTable) + // 判断该表是否已经存在 + val user = MetadataAccessUtil.getUser(userName) + val db = MetadataAccessUtil.getDatabase(user.getId, dbName) + val existedTable = MetadataAccessUtil.getTable(db.getId, tableName) + if (existedTable == null) { + throw new IllegalArgumentException("table doesn't exist " + tableName) + } + // 具体的删除索引逻辑 + + } +} From ed25e19fa17d78b5df65a69d0118b69c03ed925b Mon Sep 17 00:00:00 2001 From: zaiyuan49 Date: Tue, 9 Aug 2022 20:14:23 +0800 Subject: [PATCH 2/2] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=20drop=20index=20?= =?UTF-8?q?=E5=86=85=E5=AE=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala | 1 - 1 file changed, 1 deletion(-) diff --git a/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala b/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala index 7bdb53ce..b493773f 100644 --- a/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala +++ b/start-db-calcite/src/main/scala/org/urbcomp/start/db/parser/visitor/StartDBVisitor.scala @@ -190,7 +190,6 @@ class StartDBVisitor(user: String, db: String) extends StartDBSqlBaseVisitor[Any } def getKeyWord(list: SelectListContext): SqlNodeList = { - c if (list.selectListSet() == null) null else { val context = list.selectListSet()