BuildIndexClause.java
// 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.doris.analysis;
import org.apache.doris.alter.AlterOpType;
import org.apache.doris.catalog.DatabaseIf;
import org.apache.doris.catalog.Env;
import org.apache.doris.catalog.Index;
import org.apache.doris.catalog.OlapTable;
import org.apache.doris.catalog.Table;
import org.apache.doris.catalog.TableIf;
import org.apache.doris.common.AnalysisException;
import com.google.common.collect.Maps;
import java.util.List;
import java.util.Map;
public class BuildIndexClause extends AlterTableClause {
// in which table the index on, only used when alter = false
private TableName tableName;
// index definition class
private IndexDef indexDef;
// when alter = true, clause like: alter table add index xxxx
// when alter = false, clause like: create index xx on table xxxx
private boolean alter;
// index internal class
private Index index;
private String indexName;
private PartitionNames partitionNames;
public BuildIndexClause(TableName tableName, String indexName, PartitionNames partitionNames, boolean alter) {
super(AlterOpType.SCHEMA_CHANGE);
this.tableName = tableName;
this.indexName = indexName;
this.partitionNames = partitionNames;
this.alter = alter;
}
// for nereids
public BuildIndexClause(TableName tableName, IndexDef indexDef, Index index, boolean alter) {
super(AlterOpType.SCHEMA_CHANGE);
this.tableName = tableName;
this.indexDef = indexDef;
this.index = index;
this.alter = alter;
}
@Override
public Map<String, String> getProperties() {
return Maps.newHashMap();
}
public Index getIndex() {
return index;
}
public IndexDef getIndexDef() {
return indexDef;
}
public boolean isAlter() {
return alter;
}
public TableName getTableName() {
return tableName;
}
@Override
public void analyze(Analyzer analyzer) throws AnalysisException {
tableName.analyze(analyzer);
DatabaseIf<Table> db = Env.getCurrentEnv().getCatalogMgr().getInternalCatalog()
.getDb(tableName.getDb()).orElse(null);
if (db == null) {
throw new AnalysisException("Database[" + tableName.getDb() + "] is not exist");
}
TableIf table = db.getTable(tableName.getTbl()).orElse(null);
if (table == null) {
throw new AnalysisException("Table[" + tableName.getTbl() + "] is not exist");
}
if (!(table instanceof OlapTable)) {
throw new AnalysisException("Only olap table support build index");
}
Index existedIdx = null;
for (Index index : table.getTableIndexes().getIndexes()) {
if (index.getIndexName().equalsIgnoreCase(indexName)) {
existedIdx = index;
if (!existedIdx.isLightIndexChangeSupported()) {
throw new AnalysisException("BUILD INDEX operation failed: The index "
+ existedIdx.getIndexName() + " of type " + existedIdx.getIndexType()
+ " does not support lightweight index changes.");
}
break;
}
}
if (existedIdx == null) {
throw new AnalysisException("Index[" + indexName + "] is not exist in table[" + tableName.getTbl() + "]");
}
IndexDef.IndexType indexType = existedIdx.getIndexType();
if (!existedIdx.isLightIndexChangeSupported()) {
throw new AnalysisException(indexType.toString() + " index is not needed to build.");
}
indexDef = new IndexDef(indexName, partitionNames, indexType, true);
if (!table.isPartitionedTable()) {
List<String> specifiedPartitions = indexDef.getPartitionNames();
if (!specifiedPartitions.isEmpty()) {
throw new AnalysisException("table " + table.getName()
+ " is not partitioned, cannot build index with partitions.");
}
}
indexDef.analyze();
this.index = existedIdx.clone();
}
@Override
public boolean allowOpMTMV() {
return true;
}
@Override
public boolean needChangeMTMVState() {
return false;
}
@Override
public String toSql() {
if (alter) {
return indexDef.toSql();
} else {
return "BUILD " + indexDef.toSql(tableName.toSql());
}
}
}