diff --git a/fe/fe-core/src/main/java/org/apache/doris/analysis/AlterTableStmt.java b/fe/fe-core/src/main/java/org/apache/doris/analysis/AlterTableStmt.java index aa60bcdf813df34..9290e0ee89417b0 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/analysis/AlterTableStmt.java +++ b/fe/fe-core/src/main/java/org/apache/doris/analysis/AlterTableStmt.java @@ -212,6 +212,10 @@ public String toSql() { sb.append("DROP ROLLUP "); } sb.append(((AddRollupClause) op).getRollupName()); + } else if (op instanceof CreateIndexClause) { + sb.append(((CreateIndexClause) op).toSql(true)); + } else if (op instanceof DropIndexClause) { + sb.append(((DropIndexClause) op).toSql(true)); } else { sb.append(op.toSql()); } diff --git a/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateIndexClause.java b/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateIndexClause.java index 16f90432e7b7ab3..62d051ca318d313 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateIndexClause.java +++ b/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateIndexClause.java @@ -88,6 +88,10 @@ public boolean needChangeMTMVState() { @Override public String toSql() { + return toSql(alter); + } + + public String toSql(boolean alter) { if (alter) { return "ADD " + indexDef.toSql(); } else { diff --git a/fe/fe-core/src/main/java/org/apache/doris/analysis/DropIndexClause.java b/fe/fe-core/src/main/java/org/apache/doris/analysis/DropIndexClause.java index 783bed775be0f6d..25b4db9d16f00d1 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/analysis/DropIndexClause.java +++ b/fe/fe-core/src/main/java/org/apache/doris/analysis/DropIndexClause.java @@ -80,6 +80,10 @@ public boolean needChangeMTMVState() { @Override public String toSql() { + return toSql(alter); + } + + public String toSql(boolean alter) { StringBuilder stringBuilder = new StringBuilder(); stringBuilder.append("DROP INDEX ").append("`" + indexName + "`"); if (!alter) { diff --git a/fe/fe-core/src/test/java/org/apache/doris/analysis/AlterTableStmtTest.java b/fe/fe-core/src/test/java/org/apache/doris/analysis/AlterTableStmtTest.java index 9476df59cd14194..c968f21d6702004 100644 --- a/fe/fe-core/src/test/java/org/apache/doris/analysis/AlterTableStmtTest.java +++ b/fe/fe-core/src/test/java/org/apache/doris/analysis/AlterTableStmtTest.java @@ -126,6 +126,7 @@ public void testEnableFeature() throws UserException { @Test public void testCreateIndex() throws UserException { + // ALTER TABLE `db`.`table` ADD INDEX `index1` (`col1`) USING INVERTED COMMENT 'balabala' List ops = Lists.newArrayList(); ops.add(new CreateIndexClause( new TableName(InternalCatalog.INTERNAL_CATALOG_NAME, "db", "table"), @@ -137,8 +138,26 @@ public void testCreateIndex() throws UserException { stmt.toSql()); } + @Test + public void testCreateIndexStmt() throws UserException { + // CREATE INDEX `index1` ON `db`.`table` (`col1`) USING INVERTED COMMENT 'balabala' + CreateIndexClause createIndexClause = new CreateIndexClause( + new TableName(InternalCatalog.INTERNAL_CATALOG_NAME, "db", "table"), + new IndexDef("index1", false, Lists.newArrayList("col1"), IndexDef.IndexType.INVERTED, null, "balabala"), + false); + List ops = Lists.newArrayList(); + ops.add(createIndexClause); + AlterTableStmt stmt = new AlterTableStmt(new TableName(internalCtl, "testDb", "testTbl"), ops); + stmt.analyze(analyzer); + Assert.assertEquals("CREATE INDEX `index1` ON `db`.`table` (`col1`) USING INVERTED COMMENT 'balabala'", + createIndexClause.toSql()); + Assert.assertEquals("ALTER TABLE `testDb`.`testTbl` ADD INDEX `index1` (`col1`) USING INVERTED COMMENT 'balabala'", + stmt.toSql()); + } + @Test public void testDropIndex() throws UserException { + // ALTER TABLE `db`.`table` DROP INDEX `index1` List ops = Lists.newArrayList(); ops.add(new DropIndexClause("index1", false, new TableName(InternalCatalog.INTERNAL_CATALOG_NAME, "db", "table"), true)); @@ -146,4 +165,17 @@ public void testDropIndex() throws UserException { stmt.analyze(analyzer); Assert.assertEquals("ALTER TABLE `testDb`.`testTbl` DROP INDEX `index1`", stmt.toSql()); } + + @Test + public void testDropIndexStmt() throws UserException { + // DROP INDEX `index1` ON `db`.`table` + DropIndexClause dropIndexClause = new DropIndexClause("index1", false, + new TableName(InternalCatalog.INTERNAL_CATALOG_NAME, "db", "table"), false); + List ops = Lists.newArrayList(); + ops.add(dropIndexClause); + AlterTableStmt stmt = new AlterTableStmt(new TableName(internalCtl, "testDb", "testTbl"), ops); + stmt.analyze(analyzer); + Assert.assertEquals("DROP INDEX `index1` ON `db`.`table`", dropIndexClause.toSql()); + Assert.assertEquals("ALTER TABLE `testDb`.`testTbl` DROP INDEX `index1`", stmt.toSql()); + } }