From df31a3125122c61b0631d970c5461c12878f1c03 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 10:44:03 +0800 Subject: [PATCH 01/71] Update ClusterSchemaInfo.java --- .../persistence/schema/ClusterSchemaInfo.java | 172 ++++++++++-------- 1 file changed, 99 insertions(+), 73 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 6256458beb34..94ff233397bf 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -129,9 +129,11 @@ public class ClusterSchemaInfo implements SnapshotProcessor { // Database read write lock private final ReentrantReadWriteLock databaseReadWriteLock; - private final ConfigMTree mTree; + private final ConfigMTree treeModelMTree; + private final ConfigMTree tableModelMTree; - private static final String SNAPSHOT_FILENAME = "cluster_schema.bin"; + private static final String TREE_SNAPSHOT_FILENAME = "cluster_schema.bin"; + private static final String TABLE_SNAPSHOT_FILENAME = "table_cluster_schema.bin"; private final String ERROR_NAME = "Error Database name"; @@ -143,7 +145,8 @@ public ClusterSchemaInfo() throws IOException { databaseReadWriteLock = new ReentrantReadWriteLock(); try { - mTree = new ConfigMTree(); + treeModelMTree = new ConfigMTree(); + tableModelMTree = new ConfigMTree(); templateTable = new TemplateTable(); templatePreSetTable = new TemplatePreSetTable(); } catch (MetadataException e) { @@ -169,6 +172,9 @@ public TSStatus createDatabase(final DatabaseSchemaPlan plan) { // Set Database final TDatabaseSchema databaseSchema = plan.getSchema(); final PartialPath partialPathName = PartialPath.getDatabasePath(databaseSchema.getName()); + + final ConfigMTree mTree = + plan.getSchema().isIsTableModel() ? tableModelMTree : treeModelMTree; mTree.setStorageGroup(partialPathName); // Set DatabaseSchema @@ -200,6 +206,9 @@ public TSStatus alterDatabase(final DatabaseSchemaPlan plan) { final TDatabaseSchema alterSchema = plan.getSchema(); final PartialPath partialPathName = new PartialPath(alterSchema.getName()); + final ConfigMTree mTree = + plan.getSchema().isIsTableModel() ? tableModelMTree : treeModelMTree; + final TDatabaseSchema currentSchema = mTree.getDatabaseNodeByDatabasePath(partialPathName).getAsMNode().getDatabaseSchema(); @@ -280,7 +289,8 @@ public TSStatus deleteDatabase(final DeleteDatabasePlan plan) { databaseReadWriteLock.writeLock().lock(); try { // Delete Database - mTree.deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); + // TODO: Use TDatabaseSchema + treeModelMTree.deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); result.setCode(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (final MetadataException e) { @@ -306,8 +316,9 @@ public void checkDatabaseLimit() throws MetadataException { databaseReadWriteLock.readLock().lock(); try { int count = - mTree.getDatabaseNum(ALL_MATCH_PATTERN, ALL_MATCH_SCOPE, false) - - mTree.getDatabaseNum(SYSTEM_DATABASE_PATTERN, ALL_MATCH_SCOPE, false); + treeModelMTree.getDatabaseNum(ALL_MATCH_PATTERN, ALL_MATCH_SCOPE, false) + - treeModelMTree.getDatabaseNum(SYSTEM_DATABASE_PATTERN, ALL_MATCH_SCOPE, false) + + tableModelMTree.getDatabaseNum(ALL_MATCH_PATTERN, ALL_MATCH_SCOPE, false); if (count >= limit) { throw new SchemaQuotaExceededException(limit); } @@ -325,7 +336,7 @@ public CountDatabaseResp countMatchedDatabases(final CountDatabasePlan plan) { databaseReadWriteLock.readLock().lock(); try { final PartialPath patternPath = new PartialPath(plan.getDatabasePattern()); - result.setCount(mTree.getDatabaseNum(patternPath, plan.getScope(), false)); + result.setCount(treeModelMTree.getDatabaseNum(patternPath, plan.getScope(), false)); result.setStatus(new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode())); } catch (final MetadataException e) { LOGGER.error(ERROR_NAME, e); @@ -348,11 +359,11 @@ public DatabaseSchemaResp getMatchedDatabaseSchemas(final GetDatabasePlan plan) final Map schemaMap = new HashMap<>(); final PartialPath patternPath = new PartialPath(plan.getDatabasePattern()); final List matchedPaths = - mTree.getMatchedDatabases(patternPath, plan.getScope(), false); + treeModelMTree.getMatchedDatabases(patternPath, plan.getScope(), false); for (final PartialPath path : matchedPaths) { schemaMap.put( path.getFullPath(), - mTree.getDatabaseNodeByDatabasePath(path).getAsMNode().getDatabaseSchema()); + treeModelMTree.getDatabaseNodeByDatabasePath(path).getAsMNode().getDatabaseSchema()); } result.setSchemaMap(schemaMap); result.setStatus(new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode())); @@ -372,8 +383,8 @@ public TSStatus setSchemaReplicationFactor(final SetSchemaReplicationFactorPlan databaseReadWriteLock.writeLock().lock(); try { final PartialPath path = getQualifiedDatabasePartialPath(plan.getDatabase()); - if (mTree.isDatabaseAlreadySet(path)) { - mTree + if (treeModelMTree.isDatabaseAlreadySet(path)) { + treeModelMTree .getDatabaseNodeByDatabasePath(path) .getAsMNode() .getDatabaseSchema() @@ -396,8 +407,8 @@ public TSStatus setDataReplicationFactor(final SetDataReplicationFactorPlan plan databaseReadWriteLock.writeLock().lock(); try { final PartialPath path = getQualifiedDatabasePartialPath(plan.getDatabase()); - if (mTree.isDatabaseAlreadySet(path)) { - mTree + if (treeModelMTree.isDatabaseAlreadySet(path)) { + treeModelMTree .getDatabaseNodeByDatabasePath(path) .getAsMNode() .getDatabaseSchema() @@ -420,8 +431,8 @@ public TSStatus setTimePartitionInterval(final SetTimePartitionIntervalPlan plan databaseReadWriteLock.writeLock().lock(); try { final PartialPath path = getQualifiedDatabasePartialPath(plan.getDatabase()); - if (mTree.isDatabaseAlreadySet(path)) { - mTree + if (treeModelMTree.isDatabaseAlreadySet(path)) { + treeModelMTree .getDatabaseNodeByDatabasePath(path) .getAsMNode() .getDatabaseSchema() @@ -452,7 +463,7 @@ public TSStatus adjustMaxRegionGroupCount(final AdjustMaxRegionGroupNumPlan plan for (final Map.Entry> entry : plan.getMaxRegionGroupNumMap().entrySet()) { final TDatabaseSchema databaseSchema = - mTree + treeModelMTree .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(entry.getKey())) .getAsMNode() .getDatabaseSchema(); @@ -481,7 +492,7 @@ public TSStatus adjustMaxRegionGroupCount(final AdjustMaxRegionGroupNumPlan plan public List getDatabaseNames(final Boolean isTableModel) { databaseReadWriteLock.readLock().lock(); try { - return mTree.getAllDatabasePaths(isTableModel).stream() + return treeModelMTree.getAllDatabasePaths(isTableModel).stream() .map(PartialPath::getFullPath) .collect(Collectors.toList()); } finally { @@ -499,7 +510,7 @@ public List getDatabaseNames(final Boolean isTableModel) { public void isDatabaseNameValid(final String databaseName) throws MetadataException { databaseReadWriteLock.readLock().lock(); try { - mTree.checkDatabaseAlreadySet(getQualifiedDatabasePartialPath(databaseName)); + treeModelMTree.checkDatabaseAlreadySet(getQualifiedDatabasePartialPath(databaseName)); } finally { databaseReadWriteLock.readLock().unlock(); } @@ -516,7 +527,7 @@ public TDatabaseSchema getMatchedDatabaseSchemaByName(final String database) throws DatabaseNotExistsException { databaseReadWriteLock.readLock().lock(); try { - return mTree + return treeModelMTree .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(database)) .getAsMNode() .getDatabaseSchema(); @@ -541,11 +552,11 @@ public Map getMatchedDatabaseSchemasByName( for (final String rawPath : rawPathList) { final PartialPath patternPath = getQualifiedDatabasePartialPath(rawPath); final List matchedPaths = - mTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); + treeModelMTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); for (final PartialPath path : matchedPaths) { schemaMap.put( path.getFullPath(), - mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); + treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); } } } catch (final MetadataException e) { @@ -566,10 +577,12 @@ public Map getMatchedDatabaseSchemasByPrefix(PartialPat Map schemaMap = new HashMap<>(); databaseReadWriteLock.readLock().lock(); try { - List matchedPaths = mTree.getMatchedDatabases(prefix, ALL_MATCH_SCOPE, true); + List matchedPaths = + treeModelMTree.getMatchedDatabases(prefix, ALL_MATCH_SCOPE, true); for (PartialPath path : matchedPaths) { schemaMap.put( - path.getFullPath(), mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); + path.getFullPath(), + treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); } } catch (MetadataException e) { LOGGER.warn(ERROR_NAME, e); @@ -591,7 +604,7 @@ public int getMinRegionGroupNum( databaseReadWriteLock.readLock().lock(); try { final TDatabaseSchema storageGroupSchema = - mTree + treeModelMTree .getDatabaseNodeByDatabasePath(PartialPath.getDatabasePath(database)) .getAsMNode() .getDatabaseSchema(); @@ -622,7 +635,7 @@ public int getMaxRegionGroupNum( databaseReadWriteLock.readLock().lock(); try { final TDatabaseSchema storageGroupSchema = - mTree + treeModelMTree .getDatabaseNodeByDatabasePath(PartialPath.getDatabasePath(database)) .getAsMNode() .getDatabaseSchema(); @@ -642,14 +655,17 @@ public int getMaxRegionGroupNum( } @Override - public boolean processTakeSnapshot(File snapshotDir) throws IOException { - return processMTreeTakeSnapshot(snapshotDir) + public boolean processTakeSnapshot(final File snapshotDir) throws IOException { + return processMTreeTakeSnapshot(snapshotDir, TREE_SNAPSHOT_FILENAME, treeModelMTree) + && processMTreeTakeSnapshot(snapshotDir, TABLE_SNAPSHOT_FILENAME, tableModelMTree) && templateTable.processTakeSnapshot(snapshotDir) && templatePreSetTable.processTakeSnapshot(snapshotDir); } - public boolean processMTreeTakeSnapshot(File snapshotDir) throws IOException { - File snapshotFile = new File(snapshotDir, SNAPSHOT_FILENAME); + public boolean processMTreeTakeSnapshot( + final File snapshotDir, final String snapshotFileName, final ConfigMTree mTree) + throws IOException { + final File snapshotFile = new File(snapshotDir, snapshotFileName); if (snapshotFile.exists() && snapshotFile.isFile()) { LOGGER.error( "Failed to take snapshot, because snapshot file [{}] is already exist.", @@ -657,12 +673,12 @@ public boolean processMTreeTakeSnapshot(File snapshotDir) throws IOException { return false; } - File tmpFile = new File(snapshotFile.getAbsolutePath() + "-" + UUID.randomUUID()); + final File tmpFile = new File(snapshotFile.getAbsolutePath() + "-" + UUID.randomUUID()); databaseReadWriteLock.readLock().lock(); try { - FileOutputStream fileOutputStream = new FileOutputStream(tmpFile); - BufferedOutputStream outputStream = new BufferedOutputStream(fileOutputStream); + final FileOutputStream fileOutputStream = new FileOutputStream(tmpFile); + final BufferedOutputStream outputStream = new BufferedOutputStream(fileOutputStream); try { // Take snapshot for MTree mTree.serialize(outputStream); @@ -688,14 +704,17 @@ public boolean processMTreeTakeSnapshot(File snapshotDir) throws IOException { } @Override - public void processLoadSnapshot(File snapshotDir) throws IOException { - processMTreeLoadSnapshot(snapshotDir); + public void processLoadSnapshot(final File snapshotDir) throws IOException { + processMTreeLoadSnapshot(snapshotDir, TREE_SNAPSHOT_FILENAME, treeModelMTree); + processMTreeLoadSnapshot(snapshotDir, TABLE_SNAPSHOT_FILENAME, tableModelMTree); templateTable.processLoadSnapshot(snapshotDir); templatePreSetTable.processLoadSnapshot(snapshotDir); } - public void processMTreeLoadSnapshot(File snapshotDir) throws IOException { - File snapshotFile = new File(snapshotDir, SNAPSHOT_FILENAME); + public void processMTreeLoadSnapshot( + final File snapshotDir, final String snapshotFileName, final ConfigMTree mTree) + throws IOException { + final File snapshotFile = new File(snapshotDir, snapshotFileName); if (!snapshotFile.exists() || !snapshotFile.isFile()) { LOGGER.error( "Failed to load snapshot,snapshot file [{}] is not exist.", @@ -703,8 +722,8 @@ public void processMTreeLoadSnapshot(File snapshotDir) throws IOException { return; } databaseReadWriteLock.writeLock().lock(); - try (FileInputStream fileInputStream = new FileInputStream(snapshotFile); - BufferedInputStream bufferedInputStream = new BufferedInputStream(fileInputStream)) { + try (final FileInputStream fileInputStream = new FileInputStream(snapshotFile); + final BufferedInputStream bufferedInputStream = new BufferedInputStream(fileInputStream)) { // Load snapshot of MTree mTree.clear(); mTree.deserialize(bufferedInputStream); @@ -719,7 +738,8 @@ public Pair, Set> getNodesListInGivenLevel( new Pair(new HashSet<>(), new HashSet<>()); databaseReadWriteLock.readLock().lock(); try { - matchedPathsInNextLevel = mTree.getNodesListInGivenLevel(partialPath, level, true, scope); + matchedPathsInNextLevel = + treeModelMTree.getNodesListInGivenLevel(partialPath, level, true, scope); } catch (MetadataException e) { LOGGER.error("Error get matched paths in given level.", e); } finally { @@ -734,7 +754,7 @@ public Pair, Set> getChildNodePathInNextLevel( new Pair<>(new HashSet<>(), new HashSet<>()); databaseReadWriteLock.readLock().lock(); try { - matchedPathsInNextLevel = mTree.getChildNodePathInNextLevel(partialPath, scope); + matchedPathsInNextLevel = treeModelMTree.getChildNodePathInNextLevel(partialPath, scope); } catch (MetadataException e) { LOGGER.error("Error get matched paths in next level.", e); } finally { @@ -797,7 +817,7 @@ public synchronized TemplateInfoResp checkTemplateSettable( } try { - mTree.checkTemplateOnPath(path); + treeModelMTree.checkTemplateOnPath(path); resp.setStatus(new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode())); resp.setTemplateList( Collections.singletonList( @@ -823,7 +843,7 @@ public synchronized TSStatus setSchemaTemplate(SetSchemaTemplatePlan setSchemaTe try { int templateId = templateTable.getTemplate(setSchemaTemplatePlan.getName()).getId(); - mTree.setTemplate(templateId, path); + treeModelMTree.setTemplate(templateId, path); return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); @@ -856,13 +876,13 @@ public synchronized TSStatus preSetSchemaTemplate( private void preSetSchemaTemplate(int templateId, PartialPath templateSetPath) throws MetadataException { templatePreSetTable.preSetTemplate(templateId, templateSetPath); - mTree.setTemplate(templateId, templateSetPath); + treeModelMTree.setTemplate(templateId, templateSetPath); } private void rollbackPreSetSchemaTemplate(int templateId, PartialPath templateSetPath) throws MetadataException { try { - mTree.unsetTemplate(templateId, templateSetPath); + treeModelMTree.unsetTemplate(templateId, templateSetPath); } catch (MetadataException ignore) { // node not exists or not set template } @@ -898,7 +918,7 @@ private void commitSetSchemaTemplate(int templateId, PartialPath templateSetPath private void rollbackCommitSetSchemaTemplate(int templateId, PartialPath templateSetPath) throws MetadataException { - mTree.unsetTemplate(templateId, templateSetPath); + treeModelMTree.unsetTemplate(templateId, templateSetPath); } public PathInfoResp getPathsSetTemplate(GetPathsSetTemplatePlan getPathsSetTemplatePlan) { @@ -913,7 +933,7 @@ public PathInfoResp getPathsSetTemplate(GetPathsSetTemplatePlan getPathsSetTempl } else { templateId = templateTable.getTemplate(templateName).getId(); } - pathInfoResp.setPathList(mTree.getPathsSetOnTemplate(templateId, scope, false)); + pathInfoResp.setPathList(treeModelMTree.getPathsSetOnTemplate(templateId, scope, false)); status = new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (MetadataException e) { status = RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); @@ -929,7 +949,7 @@ public AllTemplateSetInfoResp getAllTemplateSetInfo() { for (Template template : templateList) { id = template.getId(); try { - List pathList = mTree.getPathsSetOnTemplate(id, ALL_MATCH_SCOPE, true); + List pathList = treeModelMTree.getPathsSetOnTemplate(id, ALL_MATCH_SCOPE, true); if (!pathList.isEmpty()) { List> pathSetInfoList = new ArrayList<>(); for (String path : pathList) { @@ -964,7 +984,8 @@ public TemplateSetInfoResp getTemplateSetInfo(final GetTemplateSetInfoPlan plan) try { final Map> allTemplateSetInfo = new HashMap<>(); for (final PartialPath pattern : plan.getPatternList()) { - final Map> templateSetInfo = mTree.getTemplateSetInfo(pattern); + final Map> templateSetInfo = + treeModelMTree.getTemplateSetInfo(pattern); if (templateSetInfo.isEmpty()) { continue; } @@ -1001,7 +1022,7 @@ public TemplateSetInfoResp getTemplateSetInfo(final GetTemplateSetInfoPlan plan) public TSStatus preUnsetSchemaTemplate(PreUnsetSchemaTemplatePlan plan) { try { - mTree.preUnsetTemplate(plan.getTemplateId(), plan.getPath()); + treeModelMTree.preUnsetTemplate(plan.getTemplateId(), plan.getPath()); return StatusUtils.OK; } catch (MetadataException e) { LOGGER.error(e.getMessage(), e); @@ -1011,7 +1032,7 @@ public TSStatus preUnsetSchemaTemplate(PreUnsetSchemaTemplatePlan plan) { public TSStatus rollbackUnsetSchemaTemplate(RollbackPreUnsetSchemaTemplatePlan plan) { try { - mTree.rollbackUnsetTemplate(plan.getTemplateId(), plan.getPath()); + treeModelMTree.rollbackUnsetTemplate(plan.getTemplateId(), plan.getPath()); return StatusUtils.OK; } catch (MetadataException e) { LOGGER.error(e.getMessage(), e); @@ -1021,7 +1042,7 @@ public TSStatus rollbackUnsetSchemaTemplate(RollbackPreUnsetSchemaTemplatePlan p public TSStatus unsetSchemaTemplate(UnsetSchemaTemplatePlan plan) { try { - mTree.unsetTemplate(plan.getTemplateId(), plan.getPath()); + treeModelMTree.unsetTemplate(plan.getTemplateId(), plan.getPath()); return StatusUtils.OK; } catch (MetadataException e) { LOGGER.error(e.getMessage(), e); @@ -1054,10 +1075,11 @@ public Map getMatchedDatabaseSchemasByOneName( databaseReadWriteLock.readLock().lock(); try { final PartialPath patternPath = new PartialPath(databasePathPattern); - final List matchedPaths = mTree.getBelongedDatabases(patternPath); + final List matchedPaths = treeModelMTree.getBelongedDatabases(patternPath); for (final PartialPath path : matchedPaths) { schemaMap.put( - path.getFullPath(), mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); + path.getFullPath(), + treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); } } catch (final MetadataException e) { LOGGER.warn(ERROR_NAME, e); @@ -1072,7 +1094,8 @@ public Map getMatchedDatabaseSchemasByOneName( public TSStatus preCreateTable(final PreCreateTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.preCreateTable(getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTable()); + tableModelMTree.preCreateTable( + getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTable()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); @@ -1084,7 +1107,7 @@ public TSStatus preCreateTable(final PreCreateTablePlan plan) { public TSStatus rollbackCreateTable(final RollbackCreateTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.rollbackCreateTable( + tableModelMTree.rollbackCreateTable( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { @@ -1097,7 +1120,7 @@ public TSStatus rollbackCreateTable(final RollbackCreateTablePlan plan) { public TSStatus commitCreateTable(final CommitCreateTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.commitCreateTable( + tableModelMTree.commitCreateTable( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { @@ -1110,7 +1133,7 @@ public TSStatus commitCreateTable(final CommitCreateTablePlan plan) { public TSStatus preDeleteTable(final PreDeleteTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.preDeleteTable( + treeModelMTree.preDeleteTable( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { @@ -1123,7 +1146,8 @@ public TSStatus preDeleteTable(final PreDeleteTablePlan plan) { public TSStatus dropTable(final CommitDeleteTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.dropTable(getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); + tableModelMTree.dropTable( + getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); @@ -1138,7 +1162,7 @@ public ShowTableResp showTables(final ShowTablePlan plan) { return new ShowTableResp( StatusUtils.OK, plan.isDetails() - ? mTree + ? tableModelMTree .getAllTablesUnderSpecificDatabase( getQualifiedDatabasePartialPath(plan.getDatabase())) .stream() @@ -1152,7 +1176,7 @@ public ShowTableResp showTables(final ShowTablePlan plan) { return info; }) .collect(Collectors.toList()) - : mTree + : tableModelMTree .getAllUsingTablesUnderSpecificDatabase( getQualifiedDatabasePartialPath(plan.getDatabase())) .stream() @@ -1178,7 +1202,7 @@ public FetchTableResp fetchTables(final FetchTablePlan plan) { plan.getFetchTableMap().entrySet()) { result.put( database2Tables.getKey(), - mTree.getSpecificTablesUnderSpecificDatabase( + tableModelMTree.getSpecificTablesUnderSpecificDatabase( getQualifiedDatabasePartialPath(database2Tables.getKey()), database2Tables.getValue())); } @@ -1197,11 +1221,13 @@ public DescTableResp descTable(final DescTablePlan plan) { final PartialPath databasePath = getQualifiedDatabasePartialPath(plan.getDatabase()); if (plan.isDetails()) { final Pair> pair = - mTree.getTableSchemaDetails(databasePath, plan.getTableName()); + tableModelMTree.getTableSchemaDetails(databasePath, plan.getTableName()); return new DescTableResp(StatusUtils.OK, pair.getLeft(), pair.getRight()); } return new DescTableResp( - StatusUtils.OK, mTree.getUsingTableSchema(databasePath, plan.getTableName()), null); + StatusUtils.OK, + tableModelMTree.getUsingTableSchema(databasePath, plan.getTableName()), + null); } catch (final MetadataException e) { return new DescTableResp(RpcUtils.getStatus(e.getErrorCode(), e.getMessage()), null, null); } finally { @@ -1212,7 +1238,7 @@ public DescTableResp descTable(final DescTablePlan plan) { public Map> getAllUsingTables() { databaseReadWriteLock.readLock().lock(); try { - return mTree.getAllUsingTables(); + return tableModelMTree.getAllUsingTables(); } finally { databaseReadWriteLock.readLock().unlock(); } @@ -1221,7 +1247,7 @@ public Map> getAllUsingTables() { public Map> getAllPreCreateTables() { databaseReadWriteLock.readLock().lock(); try { - return mTree.getAllPreCreateTables(); + return tableModelMTree.getAllPreCreateTables(); } catch (final MetadataException e) { LOGGER.warn(e.getMessage(), e); throw new RuntimeException(e); @@ -1234,7 +1260,7 @@ public Optional getTsTableIfExists(final String database, final String throws MetadataException { databaseReadWriteLock.readLock().lock(); try { - return mTree.getTableIfExists(getQualifiedDatabasePartialPath(database), tableName); + return tableModelMTree.getTableIfExists(getQualifiedDatabasePartialPath(database), tableName); } finally { databaseReadWriteLock.readLock().unlock(); } @@ -1244,12 +1270,12 @@ public TSStatus addTableColumn(final AddTableColumnPlan plan) { databaseReadWriteLock.writeLock().lock(); try { if (plan.isRollback()) { - mTree.rollbackAddTableColumn( + tableModelMTree.rollbackAddTableColumn( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName(), plan.getColumnSchemaList()); } else { - mTree.addTableColumn( + tableModelMTree.addTableColumn( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName(), plan.getColumnSchemaList()); @@ -1267,7 +1293,7 @@ public TSStatus renameTableColumn(final RenameTableColumnPlan plan) { final String databaseName = PathUtils.qualifyDatabaseName(plan.getDatabase()); databaseReadWriteLock.writeLock().lock(); try { - mTree.renameTableColumn( + tableModelMTree.renameTableColumn( new PartialPath(databaseName), plan.getTableName(), plan.getOldName(), plan.getNewName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { @@ -1281,7 +1307,7 @@ public TSStatus renameTableColumn(final RenameTableColumnPlan plan) { public TSStatus setTableProperties(final SetTablePropertiesPlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.setTableProperties( + tableModelMTree.setTableProperties( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName(), plan.getProperties()); @@ -1298,7 +1324,7 @@ public TSStatus preDeleteColumn(final PreDeleteColumnPlan plan) { databaseReadWriteLock.writeLock().lock(); try { final TSStatus status = new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); - if (mTree.preDeleteColumn( + if (tableModelMTree.preDeleteColumn( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName(), plan.getColumnName())) { @@ -1318,7 +1344,7 @@ public TSStatus preDeleteColumn(final PreDeleteColumnPlan plan) { public TSStatus commitDeleteColumn(final CommitDeleteColumnPlan plan) { databaseReadWriteLock.writeLock().lock(); try { - mTree.commitDeleteColumn( + tableModelMTree.commitDeleteColumn( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName(), plan.getColumnName()); @@ -1340,6 +1366,6 @@ private PartialPath getQualifiedDatabasePartialPath(final String database) @TestOnly public void clear() { - mTree.clear(); + treeModelMTree.clear(); } } From 6a9f6a4bd6aa84e352e65380324a22a90090fb06 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:17:01 +0800 Subject: [PATCH 02/71] Add --- .../request/read/database/CountDatabasePlan.java | 15 +++++++++++++-- .../request/read/database/GetDatabasePlan.java | 7 +++++-- .../iotdb/confignode/manager/ConfigManager.java | 3 ++- .../persistence/schema/ClusterSchemaInfo.java | 9 ++++++--- .../thrift/ConfigNodeRPCServiceProcessor.java | 14 +++++++++----- .../executor/ClusterConfigTaskExecutor.java | 6 ++++-- .../src/main/thrift/confignode.thrift | 1 + 7 files changed, 40 insertions(+), 15 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/CountDatabasePlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/CountDatabasePlan.java index 4772688c7015..b32fef1a36f1 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/CountDatabasePlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/CountDatabasePlan.java @@ -30,20 +30,27 @@ public class CountDatabasePlan extends ConfigPhysicalReadPlan { private final String[] storageGroupPattern; private final PathPatternTree scope; + private final boolean isTableModel; - public CountDatabasePlan(final List storageGroupPattern, final PathPatternTree scope) { + public CountDatabasePlan( + final List storageGroupPattern, + final PathPatternTree scope, + final boolean isTableModel) { super(ConfigPhysicalPlanType.CountDatabase); this.storageGroupPattern = storageGroupPattern.toArray(new String[0]); this.scope = scope; + this.isTableModel = isTableModel; } public CountDatabasePlan( final ConfigPhysicalPlanType type, final List storageGroupPattern, - final PathPatternTree scope) { + final PathPatternTree scope, + final boolean isTableModel) { super(type); this.storageGroupPattern = storageGroupPattern.toArray(new String[0]); this.scope = scope; + this.isTableModel = isTableModel; } public String[] getDatabasePattern() { @@ -54,6 +61,10 @@ public PathPatternTree getScope() { return scope; } + public boolean isTableModel() { + return isTableModel; + } + @Override public boolean equals(final Object o) { if (this == o) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/GetDatabasePlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/GetDatabasePlan.java index 2ba4c4194984..374df7eec0bc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/GetDatabasePlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/read/database/GetDatabasePlan.java @@ -26,7 +26,10 @@ public class GetDatabasePlan extends CountDatabasePlan { - public GetDatabasePlan(final List storageGroupPathPattern, final PathPatternTree scope) { - super(ConfigPhysicalPlanType.GetDatabase, storageGroupPathPattern, scope); + public GetDatabasePlan( + final List storageGroupPathPattern, + final PathPatternTree scope, + final boolean isTableModel) { + super(ConfigPhysicalPlanType.GetDatabase, storageGroupPathPattern, scope, isTableModel); } } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index 43383319f85c..712a1424ebde 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -1875,7 +1875,8 @@ public TShowDatabaseResp showDatabase(final TGetDatabaseReq req) { ? SchemaConstant.ALL_MATCH_SCOPE : PathPatternTree.deserialize(ByteBuffer.wrap(req.getScopePatternTree())); final GetDatabasePlan getDatabasePlan = - new GetDatabasePlan(req.getDatabasePathPattern(), scope); + new GetDatabasePlan( + req.getDatabasePathPattern(), scope, req.isSetIsTableModel() && req.isIsTableModel()); return getClusterSchemaManager().showDatabase(getDatabasePlan); } else { return new TShowDatabaseResp().setStatus(status); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 94ff233397bf..0fdd9536ac76 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -336,7 +336,9 @@ public CountDatabaseResp countMatchedDatabases(final CountDatabasePlan plan) { databaseReadWriteLock.readLock().lock(); try { final PartialPath patternPath = new PartialPath(plan.getDatabasePattern()); - result.setCount(treeModelMTree.getDatabaseNum(patternPath, plan.getScope(), false)); + result.setCount( + (plan.isTableModel() ? tableModelMTree : treeModelMTree) + .getDatabaseNum(patternPath, plan.getScope(), false)); result.setStatus(new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode())); } catch (final MetadataException e) { LOGGER.error(ERROR_NAME, e); @@ -358,12 +360,13 @@ public DatabaseSchemaResp getMatchedDatabaseSchemas(final GetDatabasePlan plan) try { final Map schemaMap = new HashMap<>(); final PartialPath patternPath = new PartialPath(plan.getDatabasePattern()); + final ConfigMTree mTree = plan.isTableModel() ? tableModelMTree : treeModelMTree; final List matchedPaths = - treeModelMTree.getMatchedDatabases(patternPath, plan.getScope(), false); + mTree.getMatchedDatabases(patternPath, plan.getScope(), false); for (final PartialPath path : matchedPaths) { schemaMap.put( path.getFullPath(), - treeModelMTree.getDatabaseNodeByDatabasePath(path).getAsMNode().getDatabaseSchema()); + mTree.getDatabaseNodeByDatabasePath(path).getAsMNode().getDatabaseSchema()); } result.setSchemaMap(schemaMap); result.setStatus(new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode())); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index ce360da47cfc..72b66167ef1c 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -569,7 +569,9 @@ public TCountDatabaseResp countMatchedDatabases(TGetDatabaseReq req) { req.getScopePatternTree() == null ? SchemaConstant.ALL_MATCH_SCOPE : PathPatternTree.deserialize(ByteBuffer.wrap(req.getScopePatternTree())); - CountDatabasePlan plan = new CountDatabasePlan(req.getDatabasePathPattern(), scope); + CountDatabasePlan plan = + new CountDatabasePlan( + req.getDatabasePathPattern(), scope, req.isSetIsTableModel() && req.isIsTableModel()); CountDatabaseResp countDatabaseResp = (CountDatabaseResp) configManager.countMatchedDatabases(plan); @@ -579,13 +581,15 @@ public TCountDatabaseResp countMatchedDatabases(TGetDatabaseReq req) { } @Override - public TDatabaseSchemaResp getMatchedDatabaseSchemas(TGetDatabaseReq req) { - PathPatternTree scope = + public TDatabaseSchemaResp getMatchedDatabaseSchemas(final TGetDatabaseReq req) { + final PathPatternTree scope = req.getScopePatternTree() == null ? SchemaConstant.ALL_MATCH_SCOPE : PathPatternTree.deserialize(ByteBuffer.wrap(req.getScopePatternTree())); - GetDatabasePlan plan = new GetDatabasePlan(req.getDatabasePathPattern(), scope); - DatabaseSchemaResp databaseSchemaResp = + final GetDatabasePlan plan = + new GetDatabasePlan( + req.getDatabasePathPattern(), scope, req.isSetIsTableModel() && req.isIsTableModel()); + final DatabaseSchemaResp databaseSchemaResp = (DatabaseSchemaResp) configManager.getMatchedDatabaseSchemas(plan); return databaseSchemaResp.convertToRPCStorageGroupSchemaResp(); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 286bfe8b5785..4bd05aaf84c0 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -436,7 +436,8 @@ public SettableFuture showDatabase( // Send request to some API server final TGetDatabaseReq req = new TGetDatabaseReq( - databasePathPattern, showDatabaseStatement.getAuthorityScope().serialize()); + databasePathPattern, showDatabaseStatement.getAuthorityScope().serialize()) + .setIsTableModel(false); final TShowDatabaseResp resp = client.showDatabase(req); // build TSBlock showDatabaseStatement.buildTSBlock(resp.getDatabaseInfoMap(), future); @@ -3047,7 +3048,8 @@ public SettableFuture showDatabases( CONFIG_NODE_CLIENT_MANAGER.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { // Send request to some API server final TGetDatabaseReq req = - new TGetDatabaseReq(databasePathPattern, ALL_MATCH_SCOPE.serialize()); + new TGetDatabaseReq(databasePathPattern, ALL_MATCH_SCOPE.serialize()) + .setIsTableModel(true); final TShowDatabaseResp resp = client.showDatabase(req); // build TSBlock ShowDBTask.buildTSBlock(resp.getDatabaseInfoMap(), future, showDB.isDetails(), canSeenDB); diff --git a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift index 8f2110b1672a..59b76b1630ae 100644 --- a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift +++ b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift @@ -611,6 +611,7 @@ struct TDatabaseInfo { struct TGetDatabaseReq { 1: required list databasePathPattern 2: required binary scopePatternTree + 3: optional bool isTableModel } struct TShowDatabaseResp { From f250f24ae4ff8860d33df2cdf4b5ecca763ddaae Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:29:08 +0800 Subject: [PATCH 03/71] clear db --- .../confignode/manager/schema/ClusterSchemaManager.java | 1 - .../execution/config/metadata/relational/ShowDBTask.java | 6 ------ .../plan/statement/metadata/ShowDatabaseStatement.java | 6 ------ .../iotdb/commons/schema/column/ColumnHeaderConstant.java | 7 ++----- .../thrift-confignode/src/main/thrift/confignode.thrift | 1 - 5 files changed, 2 insertions(+), 19 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 3faca89feab9..c14876f880d5 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -374,7 +374,6 @@ public TShowDatabaseResp showDatabase(final GetDatabasePlan getDatabasePlan) { getMinRegionGroupNum(database, TConsensusGroupType.DataRegion)); databaseInfo.setMaxDataRegionNum( getMaxRegionGroupNum(database, TConsensusGroupType.DataRegion)); - databaseInfo.setIsTableModel(databaseSchema.isIsTableModel()); try { databaseInfo.setSchemaRegionNum( diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java index 8873e34272b4..0b3dae7273b3 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java @@ -144,12 +144,6 @@ private static void buildTSBlockForDetails( builder.getColumnBuilder(2).writeInt(storageGroupInfo.getSchemaReplicationFactor()); builder.getColumnBuilder(3).writeInt(storageGroupInfo.getDataReplicationFactor()); builder.getColumnBuilder(4).writeLong(storageGroupInfo.getTimePartitionInterval()); - builder - .getColumnBuilder(5) - .writeBinary( - new Binary( - storageGroupInfo.isIsTableModel() ? "TABLE" : "TREE", - TSFileConfig.STRING_CHARSET)); builder.declarePosition(); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/metadata/ShowDatabaseStatement.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/metadata/ShowDatabaseStatement.java index 7c30cd29836b..8d04a48d8c3f 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/metadata/ShowDatabaseStatement.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/metadata/ShowDatabaseStatement.java @@ -105,12 +105,6 @@ public void buildTSBlock( builder.getColumnBuilder(8).writeInt(storageGroupInfo.getDataRegionNum()); builder.getColumnBuilder(9).writeInt(storageGroupInfo.getMinDataRegionNum()); builder.getColumnBuilder(10).writeInt(storageGroupInfo.getMaxDataRegionNum()); - builder - .getColumnBuilder(11) - .writeBinary( - new Binary( - storageGroupInfo.isIsTableModel() ? "TABLE" : "TREE", - TSFileConfig.STRING_CHARSET)); } builder.declarePosition(); } diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java index 81f5de255f55..dd0dfa3e72cf 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java @@ -64,7 +64,6 @@ private ColumnHeaderConstant() { public static final String DATA_REGION_GROUP_NUM = "DataRegionGroupNum"; public static final String MIN_DATA_REGION_GROUP_NUM = "MinDataRegionGroupNum"; public static final String MAX_DATA_REGION_GROUP_NUM = "MaxDataRegionGroupNum"; - public static final String MODEL = "Model"; public static final String CHILD_PATHS = "ChildPaths"; public static final String NODE_TYPES = "NodeTypes"; public static final String CHILD_NODES = "ChildNodes"; @@ -294,8 +293,7 @@ private ColumnHeaderConstant() { new ColumnHeader(MAX_SCHEMA_REGION_GROUP_NUM, TSDataType.INT32), new ColumnHeader(DATA_REGION_GROUP_NUM, TSDataType.INT32), new ColumnHeader(MIN_DATA_REGION_GROUP_NUM, TSDataType.INT32), - new ColumnHeader(MAX_DATA_REGION_GROUP_NUM, TSDataType.INT32), - new ColumnHeader(MODEL, TSDataType.TEXT)); + new ColumnHeader(MAX_DATA_REGION_GROUP_NUM, TSDataType.INT32)); public static final List showChildPathsColumnHeaders = ImmutableList.of( @@ -563,8 +561,7 @@ private ColumnHeaderConstant() { new ColumnHeader(COLUMN_TTL, TSDataType.TEXT), new ColumnHeader(SCHEMA_REPLICATION_FACTOR, TSDataType.INT32), new ColumnHeader(DATA_REPLICATION_FACTOR, TSDataType.INT32), - new ColumnHeader(TIME_PARTITION_INTERVAL, TSDataType.INT64), - new ColumnHeader(MODEL, TSDataType.TEXT)); + new ColumnHeader(TIME_PARTITION_INTERVAL, TSDataType.INT64)); public static final List describeTableColumnHeaders = ImmutableList.of( diff --git a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift index 59b76b1630ae..abe7faa3c892 100644 --- a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift +++ b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift @@ -605,7 +605,6 @@ struct TDatabaseInfo { 10: required i32 minDataRegionNum 11: required i32 maxDataRegionNum 12: optional i64 timePartitionOrigin - 13: optional bool isTableModel } struct TGetDatabaseReq { From d6ce2a62535790cde5710cf176d851dd6119fbc8 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:33:55 +0800 Subject: [PATCH 04/71] Details --- .../plan/execution/config/metadata/relational/ShowDBTask.java | 2 ++ .../iotdb/commons/schema/column/ColumnHeaderConstant.java | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java index 0b3dae7273b3..575010752afd 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java @@ -144,6 +144,8 @@ private static void buildTSBlockForDetails( builder.getColumnBuilder(2).writeInt(storageGroupInfo.getSchemaReplicationFactor()); builder.getColumnBuilder(3).writeInt(storageGroupInfo.getDataReplicationFactor()); builder.getColumnBuilder(4).writeLong(storageGroupInfo.getTimePartitionInterval()); + builder.getColumnBuilder(5).writeInt(storageGroupInfo.getSchemaRegionNum()); + builder.getColumnBuilder(6).writeInt(storageGroupInfo.getDataRegionNum()); builder.declarePosition(); } diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java index dd0dfa3e72cf..4ad114780a9d 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/schema/column/ColumnHeaderConstant.java @@ -561,7 +561,9 @@ private ColumnHeaderConstant() { new ColumnHeader(COLUMN_TTL, TSDataType.TEXT), new ColumnHeader(SCHEMA_REPLICATION_FACTOR, TSDataType.INT32), new ColumnHeader(DATA_REPLICATION_FACTOR, TSDataType.INT32), - new ColumnHeader(TIME_PARTITION_INTERVAL, TSDataType.INT64)); + new ColumnHeader(TIME_PARTITION_INTERVAL, TSDataType.INT64), + new ColumnHeader(SCHEMA_REGION_GROUP_NUM, TSDataType.INT32), + new ColumnHeader(DATA_REGION_GROUP_NUM, TSDataType.INT32)); public static final List describeTableColumnHeaders = ImmutableList.of( From f6099cfe6a0a21abf6ef74dd5e546063ab234849 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:41:09 +0800 Subject: [PATCH 05/71] partial --- .../confignode/manager/ConfigManager.java | 42 +++---------------- .../manager/schema/ClusterSchemaManager.java | 7 ++-- .../executor/ConfigPlanExecutor.java | 2 +- .../persistence/schema/ClusterSchemaInfo.java | 7 ++-- .../thrift/ConfigNodeRPCServiceProcessor.java | 26 +++++++----- 5 files changed, 29 insertions(+), 55 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index 712a1424ebde..f85caf36ae1e 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -231,7 +231,6 @@ import org.apache.iotdb.confignode.rpc.thrift.TUnsubscribeReq; import org.apache.iotdb.consensus.common.DataSet; import org.apache.iotdb.consensus.exception.ConsensusException; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.schemaengine.template.Template; import org.apache.iotdb.db.schemaengine.template.TemplateAlterOperationType; import org.apache.iotdb.db.schemaengine.template.alter.TemplateAlterOperationUtil; @@ -747,43 +746,12 @@ public synchronized TSStatus deleteDatabases(final TDeleteDatabasesReq tDeleteRe if (status.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { final List deletedPaths = tDeleteReq.getPrefixPathList(); // remove wild - final Map deleteDatabaseSchemaMap = - getClusterSchemaManager().getMatchedDatabaseSchemasByName(deletedPaths); - - // Filter by model - final int size = deleteDatabaseSchemaMap.size(); - final boolean isTableModel = tDeleteReq.isSetIsTableModel() && tDeleteReq.isIsTableModel(); - final List mismatchDatabaseNames = new ArrayList<>(); - deleteDatabaseSchemaMap - .entrySet() - .removeIf( - entry -> { - if (entry.getValue().isIsTableModel() != isTableModel) { - mismatchDatabaseNames.add(entry.getKey()); - return true; - } - return false; - }); - - if (deleteDatabaseSchemaMap.isEmpty()) { - if (size == 0) { - return RpcUtils.getStatus( - TSStatusCode.PATH_NOT_EXIST.getStatusCode(), - String.format("Path %s does not exist", Arrays.toString(deletedPaths.toArray()))); - } else if (size == 1) { - final DatabaseModelException exception = - new DatabaseModelException(mismatchDatabaseNames.get(0), !isTableModel); - return RpcUtils.getStatus(exception.getErrorCode(), exception.getMessage()); - } else { - final DatabaseModelException exception = - new DatabaseModelException(mismatchDatabaseNames, !isTableModel); - return RpcUtils.getStatus(exception.getErrorCode(), exception.getMessage()); - } - } - final ArrayList parsedDeleteDatabases = - new ArrayList<>(deleteDatabaseSchemaMap.values()); return procedureManager.deleteDatabases( - parsedDeleteDatabases, + new ArrayList<>( + getClusterSchemaManager() + .getMatchedDatabaseSchemasByName( + deletedPaths, tDeleteReq.isSetIsTableModel() && tDeleteReq.isIsTableModel()) + .values()), tDeleteReq.isSetIsGeneratedByPipe() && tDeleteReq.isIsGeneratedByPipe()); } else { return status; diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index c14876f880d5..569a53227f6e 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -457,8 +457,9 @@ public TSStatus setTimePartitionInterval( */ public synchronized void adjustMaxRegionGroupNum() { // Get all DatabaseSchemas + // TODO Map databaseSchemaMap = - getMatchedDatabaseSchemasByName(getDatabaseNames(null)); + getMatchedDatabaseSchemasByName(getDatabaseNames(null), false); if (databaseSchemaMap.isEmpty()) { // Skip when there are no Databases return; @@ -630,10 +631,10 @@ public String getDatabaseNameByDevice(final IDeviceID deviceID) { * @return the matched DatabaseSchemas */ public Map getMatchedDatabaseSchemasByName( - final List rawPathList) { + final List rawPathList, final boolean isTableModel) { final Map result = new ConcurrentHashMap<>(); clusterSchemaInfo - .getMatchedDatabaseSchemasByName(rawPathList) + .getMatchedDatabaseSchemasByName(rawPathList, isTableModel) .forEach( (database, databaseSchema) -> { if (isDatabaseExist(database)) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java index 29ce77ae5e29..26da0c8d5f5a 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java @@ -771,7 +771,7 @@ private DataSet getRegionInfoList(ConfigPhysicalPlan req) { if (showRegionReq != null && showRegionReq.isSetDatabases()) { final List storageGroups = showRegionReq.getDatabases(); final List matchedStorageGroups = - clusterSchemaInfo.getMatchedDatabaseSchemasByName(storageGroups).values().stream() + clusterSchemaInfo.getMatchedDatabaseSchemasByName(storageGroups, false).values().stream() .map(TDatabaseSchema::getName) .collect(Collectors.toList()); if (!matchedStorageGroups.isEmpty()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 0fdd9536ac76..53d6006a7a6a 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -548,18 +548,19 @@ public TDatabaseSchema getMatchedDatabaseSchemaByName(final String database) * @return All DatabaseSchemas that matches to the specific Database patterns */ public Map getMatchedDatabaseSchemasByName( - final List rawPathList) { + final List rawPathList, final boolean isTableModel) { final Map schemaMap = new HashMap<>(); databaseReadWriteLock.readLock().lock(); try { + final ConfigMTree mTree = isTableModel ? tableModelMTree : treeModelMTree; for (final String rawPath : rawPathList) { final PartialPath patternPath = getQualifiedDatabasePartialPath(rawPath); final List matchedPaths = - treeModelMTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); + mTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); for (final PartialPath path : matchedPaths) { schemaMap.put( path.getFullPath(), - treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); + mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); } } } catch (final MetadataException e) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 72b66167ef1c..bd404234ed44 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -529,53 +529,56 @@ public TSStatus alterDatabase(final TDatabaseSchema databaseSchema) { } @Override - public TSStatus deleteDatabase(TDeleteDatabaseReq tDeleteReq) { + public TSStatus deleteDatabase(final TDeleteDatabaseReq tDeleteReq) { return configManager.deleteDatabases( new TDeleteDatabasesReq(Collections.singletonList(tDeleteReq.getPrefixPath())) .setIsGeneratedByPipe(tDeleteReq.isIsGeneratedByPipe())); } @Override - public TSStatus deleteDatabases(TDeleteDatabasesReq tDeleteReq) { + public TSStatus deleteDatabases(final TDeleteDatabasesReq tDeleteReq) { return configManager.deleteDatabases(tDeleteReq); } @Override - public TSStatus setTTL(TSetTTLReq req) throws TException { + public TSStatus setTTL(final TSetTTLReq req) throws TException { return configManager.setTTL(new SetTTLPlan(req.getPathPattern(), req.getTTL())); } @Override - public TSStatus setSchemaReplicationFactor(TSetSchemaReplicationFactorReq req) throws TException { + public TSStatus setSchemaReplicationFactor(final TSetSchemaReplicationFactorReq req) + throws TException { return configManager.setSchemaReplicationFactor( new SetSchemaReplicationFactorPlan(req.getDatabase(), req.getSchemaReplicationFactor())); } @Override - public TSStatus setDataReplicationFactor(TSetDataReplicationFactorReq req) throws TException { + public TSStatus setDataReplicationFactor(final TSetDataReplicationFactorReq req) + throws TException { return configManager.setDataReplicationFactor( new SetDataReplicationFactorPlan(req.getDatabase(), req.getDataReplicationFactor())); } @Override - public TSStatus setTimePartitionInterval(TSetTimePartitionIntervalReq req) throws TException { + public TSStatus setTimePartitionInterval(final TSetTimePartitionIntervalReq req) + throws TException { return configManager.setTimePartitionInterval( new SetTimePartitionIntervalPlan(req.getDatabase(), req.getTimePartitionInterval())); } @Override - public TCountDatabaseResp countMatchedDatabases(TGetDatabaseReq req) { - PathPatternTree scope = + public TCountDatabaseResp countMatchedDatabases(final TGetDatabaseReq req) { + final PathPatternTree scope = req.getScopePatternTree() == null ? SchemaConstant.ALL_MATCH_SCOPE : PathPatternTree.deserialize(ByteBuffer.wrap(req.getScopePatternTree())); - CountDatabasePlan plan = + final CountDatabasePlan plan = new CountDatabasePlan( req.getDatabasePathPattern(), scope, req.isSetIsTableModel() && req.isIsTableModel()); - CountDatabaseResp countDatabaseResp = + final CountDatabaseResp countDatabaseResp = (CountDatabaseResp) configManager.countMatchedDatabases(plan); - TCountDatabaseResp resp = new TCountDatabaseResp(); + final TCountDatabaseResp resp = new TCountDatabaseResp(); countDatabaseResp.convertToRPCCountStorageGroupResp(resp); return resp; } @@ -988,6 +991,7 @@ public TGetDataNodeLocationsResp getRunningDataNodeLocations() { @Override public TShowRegionResp showRegion(TShowRegionReq showRegionReq) { + // TODO: Model GetRegionInfoListPlan getRegionInfoListPlan = new GetRegionInfoListPlan(showRegionReq); RegionInfoListResp dataSet = configManager.showRegion(getRegionInfoListPlan); TShowRegionResp showRegionResp = new TShowRegionResp(); From 915b36e59ef45c5421d962cbdddb2ded322d8b46 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:48:06 +0800 Subject: [PATCH 06/71] cleaning --- .../persistence/schema/ClusterSchemaInfo.java | 12 ----- .../persistence/schema/ConfigMTree.java | 7 --- .../metadata/DatabaseModelException.java | 53 ------------------- .../plan/analyze/ClusterPartitionFetcher.java | 12 ++--- .../cache/partition/PartitionCache.java | 33 ++++-------- .../executor/ClusterConfigTaskExecutor.java | 13 ++--- .../analyze/cache/PartitionCacheTest.java | 3 +- 7 files changed, 18 insertions(+), 115 deletions(-) delete mode 100644 iotdb-core/datanode/src/main/java/org/apache/iotdb/db/exception/metadata/DatabaseModelException.java diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 53d6006a7a6a..ca51c7c5dc78 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -79,7 +79,6 @@ import org.apache.iotdb.confignode.exception.DatabaseNotExistsException; import org.apache.iotdb.confignode.rpc.thrift.TDatabaseSchema; import org.apache.iotdb.confignode.rpc.thrift.TTableInfo; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.exception.metadata.SchemaQuotaExceededException; import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.schemaengine.template.Template; @@ -212,17 +211,6 @@ public TSStatus alterDatabase(final DatabaseSchemaPlan plan) { final TDatabaseSchema currentSchema = mTree.getDatabaseNodeByDatabasePath(partialPathName).getAsMNode().getDatabaseSchema(); - // Model conflict detection - if (alterSchema.isIsTableModel() && !currentSchema.isIsTableModel()) { - final DatabaseModelException exception = - new DatabaseModelException(currentSchema.getName(), false); - return RpcUtils.getStatus(exception.getErrorCode(), exception.getMessage()); - } else if (!alterSchema.isIsTableModel() && currentSchema.isIsTableModel()) { - final DatabaseModelException exception = - new DatabaseModelException(currentSchema.getName(), true); - return RpcUtils.getStatus(exception.getErrorCode(), exception.getMessage()); - } - // TODO: Support alter other fields if (alterSchema.isSetMinSchemaRegionGroupNum()) { currentSchema.setMinSchemaRegionGroupNum(alterSchema.getMinSchemaRegionGroupNum()); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java index 5041be35a5e0..c6ca00ab4632 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java @@ -38,7 +38,6 @@ import org.apache.iotdb.confignode.persistence.schema.mnode.impl.ConfigTableNode; import org.apache.iotdb.db.exception.metadata.DatabaseAlreadySetException; import org.apache.iotdb.db.exception.metadata.DatabaseConflictException; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.exception.metadata.DatabaseNotSetException; import org.apache.iotdb.db.exception.metadata.PathAlreadyExistException; import org.apache.iotdb.db.exception.metadata.PathNotExistException; @@ -486,9 +485,6 @@ public void checkTemplateOnPath(final PartialPath path) throws MetadataException if (cur.getSchemaTemplateId() != NON_TEMPLATE) { throw new MetadataException("Template already exists on " + cur.getFullPath()); } - if (cur.isDatabase() && cur.getDatabaseSchema().isIsTableModel()) { - throw new DatabaseModelException(cur.getFullPath(), true); - } } checkTemplateOnSubtree(cur); @@ -651,9 +647,6 @@ private IConfigMNode getNodeSetTemplate(int templateId, PartialPath path) public void preCreateTable(final PartialPath database, final TsTable table) throws MetadataException { final IConfigMNode databaseNode = getDatabaseNodeByDatabasePath(database).getAsMNode(); - if (!databaseNode.getDatabaseSchema().isIsTableModel()) { - throw new DatabaseModelException(database.getFullPath(), false); - } final IConfigMNode node = databaseNode.getChild(table.getTableName()); if (node == null) { final ConfigTableNode tableNode = diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/exception/metadata/DatabaseModelException.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/exception/metadata/DatabaseModelException.java deleted file mode 100644 index 0ddf1174d371..000000000000 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/exception/metadata/DatabaseModelException.java +++ /dev/null @@ -1,53 +0,0 @@ -/* - * 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.iotdb.db.exception.metadata; - -import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.utils.PathUtils; -import org.apache.iotdb.rpc.TSStatusCode; - -import java.util.List; -import java.util.stream.Collectors; - -public class DatabaseModelException extends MetadataException { - public DatabaseModelException(final String path, final boolean isTableModel) { - super( - "The database " - + (isTableModel - ? PathUtils.qualifyDatabaseName(path) - : PathUtils.unQualifyDatabaseName(path)) - + " is a " - + (isTableModel ? "table" : "tree") - + " model database.", - TSStatusCode.DATABASE_MODEL.getStatusCode()); - } - - public DatabaseModelException(final List paths, final boolean isTableModel) { - super( - "The databases " - + (isTableModel - ? paths.stream().map(PathUtils::qualifyDatabaseName).collect(Collectors.toList()) - : paths.stream().map(PathUtils::unQualifyDatabaseName).collect(Collectors.toList())) - + " are all " - + (isTableModel ? "table" : "tree") - + " model databases.", - TSStatusCode.DATABASE_MODEL.getStatusCode()); - } -} diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index 53b1c9420461..9a89c9f764d8 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -46,7 +46,6 @@ import org.apache.iotdb.confignode.rpc.thrift.TTimeSlotList; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.exception.sql.StatementAnalyzeException; import org.apache.iotdb.db.protocol.client.ConfigNodeClient; @@ -129,7 +128,7 @@ private SchemaPartition getSchemaPartitionWithModel( } } return schemaPartition; - } catch (final ClientManagerException | TException | DatabaseModelException e) { + } catch (final ClientManagerException | TException e) { throw new StatementAnalyzeException( "An error occurred when executing getSchemaPartition():" + e.getMessage()); } @@ -161,7 +160,7 @@ public SchemaPartition getOrCreateSchemaPartition( } } return schemaPartition; - } catch (final ClientManagerException | TException | DatabaseModelException e) { + } catch (final ClientManagerException | TException e) { throw new StatementAnalyzeException( "An error occurred when executing getOrCreateSchemaPartition():" + e.getMessage()); } @@ -288,7 +287,7 @@ public DataPartition getOrCreateDataPartition( dataPartitionTableResp.getStatus().getCode())); } } - } catch (final ClientManagerException | TException | DatabaseModelException e) { + } catch (final ClientManagerException | TException e) { throw new StatementAnalyzeException( "An error occurred when executing getOrCreateDataPartition():" + e.getMessage()); } @@ -352,7 +351,7 @@ private SchemaPartition getOrCreateSchemaPartition( } } return schemaPartition; - } catch (final ClientManagerException | TException | DatabaseModelException e) { + } catch (final ClientManagerException | TException e) { throw new StatementAnalyzeException( "An error occurred when executing getSchemaPartition():" + e.getMessage()); } @@ -375,8 +374,7 @@ public SchemaPartition getSchemaPartition(final String database) { private Map> splitDataPartitionQueryParam( final List dataPartitionQueryParams, final boolean isAutoCreate, - final String userName) - throws DatabaseModelException { + final String userName) { final List deviceIDs = new ArrayList<>(); for (final DataPartitionQueryParam dataPartitionQueryParam : dataPartitionQueryParams) { deviceIDs.add(dataPartitionQueryParam.getDeviceID()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java index e5d11d74f785..fcd1f310ad14 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java @@ -48,7 +48,6 @@ import org.apache.iotdb.db.auth.AuthorityChecker; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.exception.sql.StatementAnalyzeException; import org.apache.iotdb.db.protocol.client.ConfigNodeClient; import org.apache.iotdb.db.protocol.client.ConfigNodeClientManager; @@ -141,8 +140,7 @@ public Map> getDatabaseToDevice( final List deviceIDs, final boolean tryToFetch, final boolean isAutoCreate, - final String userName) - throws DatabaseModelException { + final String userName) { final DatabaseCacheResult> result = new DatabaseCacheResult>() { @Override @@ -166,8 +164,7 @@ public Map getDeviceToDatabase( final List deviceIDs, final boolean tryToFetch, final boolean isAutoCreate, - final String userName) - throws DatabaseModelException { + final String userName) { final DatabaseCacheResult result = new DatabaseCacheResult() { @Override @@ -185,13 +182,10 @@ public void put(final IDeviceID device, final String databaseName) { * @param deviceID the path of device * @return database name, return {@code null} if cache miss */ - private String getDatabaseName(final IDeviceID deviceID) throws DatabaseModelException { + private String getDatabaseName(final IDeviceID deviceID) { for (final Map.Entry entry : databaseCache.entrySet()) { final String database = entry.getKey(); if (PathUtils.isStartWith(deviceID, database)) { - if (Boolean.TRUE.equals(entry.getValue())) { - throw new DatabaseModelException(database, true); - } return entry.getKey(); } } @@ -204,16 +198,10 @@ private String getDatabaseName(final IDeviceID deviceID) throws DatabaseModelExc * @param database name * @return {@code true} if this database exists */ - private boolean containsDatabase(final String database) throws DatabaseModelException { + private boolean containsDatabase(final String database) { try { databaseCacheLock.readLock().lock(); - if (databaseCache.containsKey(database)) { - if (Boolean.FALSE.equals(databaseCache.get(database))) { - throw new DatabaseModelException(PathUtils.unQualifyDatabaseName(database), false); - } - return true; - } - return false; + return databaseCache.containsKey(database); } finally { databaseCacheLock.readLock().unlock(); } @@ -227,7 +215,7 @@ private boolean containsDatabase(final String database) throws DatabaseModelExce */ private void fetchDatabaseAndUpdateCache( final DatabaseCacheResult result, final List deviceIDs) - throws ClientManagerException, TException, DatabaseModelException { + throws ClientManagerException, TException { databaseCacheLock.writeLock().lock(); try (final ConfigNodeClient client = configNodeClientManager.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { @@ -414,8 +402,7 @@ private void createDatabaseAndUpdateCache(final String database, final String us private void getDatabaseMap( final DatabaseCacheResult result, final List deviceIDs, - final boolean failFast) - throws DatabaseModelException { + final boolean failFast) { try { databaseCacheLock.readLock().lock(); // reset result before try @@ -464,8 +451,7 @@ private void getDatabaseCacheResult( final List deviceIDs, final boolean tryToFetch, final boolean isAutoCreate, - final String userName) - throws DatabaseModelException { + final String userName) { if (!isAutoCreate) { // TODO: avoid IDeviceID contains "*" // miss when deviceId contains * @@ -498,8 +484,7 @@ private void getDatabaseCacheResult( } public void checkAndAutoCreateDatabase( - final String database, final boolean isAutoCreate, final String userName) - throws DatabaseModelException { + final String database, final boolean isAutoCreate, final String userName) { boolean isExisted = containsDatabase(database); if (!isExisted) { try { diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 4bd05aaf84c0..93b3e5619ba8 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -139,7 +139,6 @@ import org.apache.iotdb.db.conf.IoTDBDescriptor; import org.apache.iotdb.db.exception.BatchProcessException; import org.apache.iotdb.db.exception.StorageEngineException; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.exception.metadata.PathNotExistException; import org.apache.iotdb.db.exception.metadata.SchemaQuotaExceededException; import org.apache.iotdb.db.exception.sql.SemanticException; @@ -3078,16 +3077,10 @@ public SettableFuture useDatabase( CONFIG_NODE_CLIENT_MANAGER.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { // Send request to some API server final TGetDatabaseReq req = - new TGetDatabaseReq(databasePathPattern, ALL_MATCH_SCOPE.serialize()); + new TGetDatabaseReq(databasePathPattern, ALL_MATCH_SCOPE.serialize()) + .setIsTableModel(true); final TShowDatabaseResp resp = client.showDatabase(req); if (!resp.getDatabaseInfoMap().isEmpty()) { - if (!resp.getDatabaseInfoMap() - .get(PathUtils.qualifyDatabaseName(useDB.getDatabaseId().getValue())) - .isIsTableModel()) { - throw new IoTDBException( - new DatabaseModelException(useDB.getDatabaseId().getValue(), false).getMessage(), - TSStatusCode.DATABASE_MODEL.getStatusCode()); - } clientSession.setDatabaseName(useDB.getDatabaseId().getValue()); future.set(new ConfigTaskResult(TSStatusCode.SUCCESS_STATUS)); } else { @@ -3096,7 +3089,7 @@ public SettableFuture useDatabase( String.format("Unknown database %s", useDB.getDatabaseId().getValue()), TSStatusCode.DATABASE_NOT_EXIST.getStatusCode())); } - } catch (final IOException | ClientManagerException | TException | IoTDBException e) { + } catch (final IOException | ClientManagerException | TException e) { future.setException(e); } return future; diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java index 725860eb70d2..0bd2c44ecb62 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java @@ -32,7 +32,6 @@ import org.apache.iotdb.db.auth.AuthorityChecker; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; -import org.apache.iotdb.db.exception.metadata.DatabaseModelException; import org.apache.iotdb.db.queryengine.plan.analyze.cache.partition.PartitionCache; import org.apache.tsfile.file.metadata.IDeviceID; @@ -164,7 +163,7 @@ public void tearDown() throws Exception { } @Test - public void testStorageGroupCache() throws DatabaseModelException { + public void testStorageGroupCache() { Map> storageGroupToDeviceMap; Map deviceToStorageGroupMap; // test devices in one database From 04dd9850a5f935992e83796b2895ea94d31d5433 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:53:49 +0800 Subject: [PATCH 07/71] revert --- .../cache/partition/PartitionCache.java | 25 ++++++++----------- .../analyze/cache/PartitionCacheTest.java | 5 +--- 2 files changed, 12 insertions(+), 18 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java index fcd1f310ad14..43e90bdaad1d 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java @@ -89,7 +89,7 @@ public class PartitionCache { private final SeriesPartitionExecutor partitionExecutor; /** the cache of database */ - private final Map databaseCache = new HashMap<>(); + private final Set databaseCache = new HashSet<>(); /** database -> schemaPartitionTable */ private final Cache schemaPartitionCache; @@ -183,10 +183,9 @@ public void put(final IDeviceID device, final String databaseName) { * @return database name, return {@code null} if cache miss */ private String getDatabaseName(final IDeviceID deviceID) { - for (final Map.Entry entry : databaseCache.entrySet()) { - final String database = entry.getKey(); + for (final String database : databaseCache) { if (PathUtils.isStartWith(deviceID, database)) { - return entry.getKey(); + return database; } } return null; @@ -201,7 +200,7 @@ private String getDatabaseName(final IDeviceID deviceID) { private boolean containsDatabase(final String database) { try { databaseCacheLock.readLock().lock(); - return databaseCache.containsKey(database); + return databaseCache.contains(database); } finally { databaseCacheLock.readLock().unlock(); } @@ -223,7 +222,8 @@ private void fetchDatabaseAndUpdateCache( getDatabaseMap(result, deviceIDs, true); if (!result.isSuccess()) { final TGetDatabaseReq req = - new TGetDatabaseReq(ROOT_PATH, SchemaConstant.ALL_MATCH_SCOPE_BINARY); + new TGetDatabaseReq(ROOT_PATH, SchemaConstant.ALL_MATCH_SCOPE_BINARY) + .setIsTableModel(false); final TDatabaseSchemaResp databaseSchemaResp = client.getMatchedDatabaseSchemas(req); if (databaseSchemaResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { @@ -247,15 +247,12 @@ private void fetchDatabaseAndUpdateCache() throws ClientManagerException, TExcep try (final ConfigNodeClient client = configNodeClientManager.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { final TGetDatabaseReq req = - new TGetDatabaseReq(ROOT_PATH, SchemaConstant.ALL_MATCH_SCOPE_BINARY); + new TGetDatabaseReq(ROOT_PATH, SchemaConstant.ALL_MATCH_SCOPE_BINARY) + .setIsTableModel(true); final TDatabaseSchemaResp databaseSchemaResp = client.getMatchedDatabaseSchemas(req); if (databaseSchemaResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // update all database into cache - updateDatabaseCache( - databaseSchemaResp.getDatabaseSchemaMap().entrySet().stream() - .collect( - Collectors.toMap( - Map.Entry::getKey, entry -> entry.getValue().isIsTableModel()))); + updateDatabaseCache(databaseSchemaResp.getDatabaseSchemaMap()); } } finally { databaseCacheLock.writeLock().unlock(); @@ -507,10 +504,10 @@ public void checkAndAutoCreateDatabase( * * @param databaseNames the database names that need to update */ - public void updateDatabaseCache(final Map databaseNames) { + public void updateDatabaseCache(final Set databaseNames) { databaseCacheLock.writeLock().lock(); try { - databaseCache.putAll(databaseNames); + databaseCache.addAll(databaseNames); } finally { databaseCacheLock.writeLock().unlock(); } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java index 0bd2c44ecb62..c198c3971b45 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/PartitionCacheTest.java @@ -48,8 +48,6 @@ import java.util.List; import java.util.Map; import java.util.Set; -import java.util.function.Function; -import java.util.stream.Collectors; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; @@ -150,8 +148,7 @@ private static String getDeviceName(String storageGroupName, int deviceNumber) { @Before public void setUp() throws Exception { partitionCache = new PartitionCache(); - partitionCache.updateDatabaseCache( - storageGroups.stream().collect(Collectors.toMap(Function.identity(), k -> false))); + partitionCache.updateDatabaseCache(storageGroups); partitionCache.updateSchemaPartitionCache(schemaPartitionTable); partitionCache.updateDataPartitionCache(dataPartitionTable); partitionCache.updateGroupIdToReplicaSetMap(100, consensusGroupIdToRegionReplicaSet); From 910322a3642611e7a49e229b56ee1b3d2be143ec Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:56:30 +0800 Subject: [PATCH 08/71] partial --- .../cache/partition/PartitionCache.java | 15 +++++---------- .../relational/metadata/TableMetadataImpl.java | 18 ++++++++---------- 2 files changed, 13 insertions(+), 20 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java index 43e90bdaad1d..f84d0477d107 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java @@ -74,7 +74,6 @@ import java.util.Set; import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.locks.ReentrantReadWriteLock; -import java.util.stream.Collectors; public class PartitionCache { @@ -228,11 +227,7 @@ private void fetchDatabaseAndUpdateCache( if (databaseSchemaResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // update all database into cache - updateDatabaseCache( - databaseSchemaResp.getDatabaseSchemaMap().entrySet().stream() - .collect( - Collectors.toMap( - Map.Entry::getKey, entry -> entry.getValue().isIsTableModel()))); + updateDatabaseCache(databaseSchemaResp.getDatabaseSchemaMap().keySet()); getDatabaseMap(result, deviceIDs, true); } } @@ -252,7 +247,7 @@ private void fetchDatabaseAndUpdateCache() throws ClientManagerException, TExcep final TDatabaseSchemaResp databaseSchemaResp = client.getMatchedDatabaseSchemas(req); if (databaseSchemaResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // update all database into cache - updateDatabaseCache(databaseSchemaResp.getDatabaseSchemaMap()); + updateDatabaseCache(databaseSchemaResp.getDatabaseSchemaMap().keySet()); } } finally { databaseCacheLock.writeLock().unlock(); @@ -294,7 +289,7 @@ private void createDatabaseAndUpdateCache( } // Try to create databases one by one until done or one database fail - final Map successFullyCreatedDatabase = new HashMap<>(); + final Set successFullyCreatedDatabase = new HashSet<>(); for (final String databaseName : databaseNamesNeedCreated) { final long startTime = System.nanoTime(); try { @@ -318,7 +313,7 @@ private void createDatabaseAndUpdateCache( final TSStatus tsStatus = client.setDatabase(databaseSchema); if (TSStatusCode.SUCCESS_STATUS.getStatusCode() == tsStatus.getCode() || TSStatusCode.DATABASE_ALREADY_EXISTS.getStatusCode() == tsStatus.getCode()) { - successFullyCreatedDatabase.put(databaseName, false); + successFullyCreatedDatabase.add(databaseName); // In tree model, if the user creates a conflict database concurrently, for instance, // the database created by user is root.db.ss.a, the auto-creation failed database is // root.db, we wait till "getOrCreatePartition" to judge if the time series (like @@ -377,7 +372,7 @@ private void createDatabaseAndUpdateCache(final String database, final String us if (TSStatusCode.SUCCESS_STATUS.getStatusCode() == tsStatus.getCode() || TSStatusCode.DATABASE_ALREADY_EXISTS.getStatusCode() == tsStatus.getCode()) { // Try to update cache by databases successfully created - updateDatabaseCache(Collections.singletonMap(database, true)); + updateDatabaseCache(Collections.singleton(database)); } else { logger.warn( "[{} Cache] failed to create database {}", CacheMetrics.DATABASE_CACHE_NAME, database); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java index c88a73d87c9e..be86c26cbba6 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java @@ -66,8 +66,6 @@ import java.util.Optional; import java.util.stream.Collectors; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_ROOT; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_SEPARATOR; import static org.apache.iotdb.commons.schema.table.InformationSchemaTable.INFORMATION_SCHEMA; import static org.apache.tsfile.read.common.type.BinaryType.TEXT; import static org.apache.tsfile.read.common.type.BooleanType.BOOLEAN; @@ -718,25 +716,25 @@ public void validateDeviceSchema( @Override public DataPartition getOrCreateDataPartition( - List dataPartitionQueryParams, String userName) { + final List dataPartitionQueryParams, final String userName) { return partitionFetcher.getOrCreateDataPartition(dataPartitionQueryParams, userName); } @Override public SchemaPartition getOrCreateSchemaPartition( - String database, List deviceIDList, String userName) { - return partitionFetcher.getOrCreateSchemaPartition( - PATH_ROOT + PATH_SEPARATOR + database, deviceIDList, userName); + final String database, final List deviceIDList, final String userName) { + return partitionFetcher.getOrCreateSchemaPartition(database, deviceIDList, userName); } @Override - public SchemaPartition getSchemaPartition(String database, List deviceIDList) { - return partitionFetcher.getSchemaPartition(PATH_ROOT + PATH_SEPARATOR + database, deviceIDList); + public SchemaPartition getSchemaPartition( + final String database, final List deviceIDList) { + return partitionFetcher.getSchemaPartition(database, deviceIDList); } @Override - public SchemaPartition getSchemaPartition(String database) { - return partitionFetcher.getSchemaPartition(PATH_ROOT + PATH_SEPARATOR + database); + public SchemaPartition getSchemaPartition(final String database) { + return partitionFetcher.getSchemaPartition(database); } @Override From 22edbbbf6c70976bee9c3dcfbff6ef98e16da6b5 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:12:32 +0800 Subject: [PATCH 09/71] refactor --- .../database/AdjustMaxRegionGroupNumPlan.java | 20 ++++----- .../manager/partition/PartitionManager.java | 34 +++++++-------- .../manager/schema/ClusterSchemaManager.java | 31 ++++++------- .../executor/ConfigPlanExecutor.java | 4 +- .../persistence/partition/PartitionInfo.java | 6 +-- .../persistence/schema/ClusterSchemaInfo.java | 43 ++++++++++++------- .../persistence/schema/ConfigMTree.java | 4 +- .../config/TableConfigTaskVisitor.java | 4 +- .../AbstractAlterOrDropTableTask.java | 4 +- .../table/DataNodeTableCache.java | 4 +- 10 files changed, 80 insertions(+), 74 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/AdjustMaxRegionGroupNumPlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/AdjustMaxRegionGroupNumPlan.java index c6dbd600278a..42b98cc30d03 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/AdjustMaxRegionGroupNumPlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/AdjustMaxRegionGroupNumPlan.java @@ -42,7 +42,7 @@ public AdjustMaxRegionGroupNumPlan() { this.maxRegionGroupNumMap = new HashMap<>(); } - public void putEntry(String storageGroup, Pair maxRegionGroupNum) { + public void putEntry(final String storageGroup, final Pair maxRegionGroupNum) { maxRegionGroupNumMap.put(storageGroup, maxRegionGroupNum); } @@ -51,11 +51,11 @@ public Map> getMaxRegionGroupNumMap() { } @Override - protected void serializeImpl(DataOutputStream stream) throws IOException { + protected void serializeImpl(final DataOutputStream stream) throws IOException { ReadWriteIOUtils.write(getType().getPlanType(), stream); ReadWriteIOUtils.write(maxRegionGroupNumMap.size(), stream); - for (Map.Entry> maxRegionGroupNumEntry : + for (final Map.Entry> maxRegionGroupNumEntry : maxRegionGroupNumMap.entrySet()) { ReadWriteIOUtils.write(maxRegionGroupNumEntry.getKey(), stream); ReadWriteIOUtils.write(maxRegionGroupNumEntry.getValue().getLeft(), stream); @@ -64,27 +64,27 @@ protected void serializeImpl(DataOutputStream stream) throws IOException { } @Override - protected void deserializeImpl(ByteBuffer buffer) throws IOException { - int storageGroupNum = buffer.getInt(); + protected void deserializeImpl(final ByteBuffer buffer) throws IOException { + final int storageGroupNum = buffer.getInt(); for (int i = 0; i < storageGroupNum; i++) { - String storageGroup = ReadWriteIOUtils.readString(buffer); - int maxSchemaRegionGroupNum = buffer.getInt(); - int maxDataRegionGroupNum = buffer.getInt(); + final String storageGroup = ReadWriteIOUtils.readString(buffer); + final int maxSchemaRegionGroupNum = buffer.getInt(); + final int maxDataRegionGroupNum = buffer.getInt(); maxRegionGroupNumMap.put( storageGroup, new Pair<>(maxSchemaRegionGroupNum, maxDataRegionGroupNum)); } } @Override - public boolean equals(Object o) { + public boolean equals(final Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } - AdjustMaxRegionGroupNumPlan that = (AdjustMaxRegionGroupNumPlan) o; + final AdjustMaxRegionGroupNumPlan that = (AdjustMaxRegionGroupNumPlan) o; return maxRegionGroupNumMap.equals(that.maxRegionGroupNumMap); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index f1ac99a562a6..d242c5a2c3b8 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -172,12 +172,12 @@ private void setSeriesPartitionExecutor() { * @param req SchemaPartitionPlan with partitionSlotsMap * @return SchemaPartitionDataSet that contains only existing SchemaPartition */ - public SchemaPartitionResp getSchemaPartition(GetSchemaPartitionPlan req) { + public SchemaPartitionResp getSchemaPartition(final GetSchemaPartitionPlan req) { try { return (SchemaPartitionResp) getConsensusManager().read(req); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_READ_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); return new SchemaPartitionResp(res, false, Collections.emptyMap()); } @@ -190,12 +190,12 @@ public SchemaPartitionResp getSchemaPartition(GetSchemaPartitionPlan req) { * TTimeSlotList>> * @return DataPartitionDataSet that contains only existing DataPartition */ - public DataPartitionResp getDataPartition(GetDataPartitionPlan req) { + public DataPartitionResp getDataPartition(final GetDataPartitionPlan req) { try { return (DataPartitionResp) getConsensusManager().read(req); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_READ_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); return new DataPartitionResp(res, false, Collections.emptyMap()); } @@ -209,9 +209,9 @@ public DataPartitionResp getDataPartition(GetDataPartitionPlan req) { * finish. NOT_ENOUGH_DATA_NODE if the DataNodes is not enough to create new Regions. * STORAGE_GROUP_NOT_EXIST if some StorageGroup don't exist. */ - public SchemaPartitionResp getOrCreateSchemaPartition(GetOrCreateSchemaPartitionPlan req) { + public SchemaPartitionResp getOrCreateSchemaPartition(final GetOrCreateSchemaPartitionPlan req) { // Check if the related Databases exist - for (String database : req.getPartitionSlotsMap().keySet()) { + for (final String database : req.getPartitionSlotsMap().keySet()) { if (!isDatabaseExist(database)) { return new SchemaPartitionResp( new TSStatus(TSStatusCode.DATABASE_NOT_EXIST.getStatusCode()) @@ -245,14 +245,14 @@ public SchemaPartitionResp getOrCreateSchemaPartition(GetOrCreateSchemaPartition } // Filter unassigned SchemaPartitionSlots - Map> unassignedSchemaPartitionSlotsMap = + final Map> unassignedSchemaPartitionSlotsMap = partitionInfo.filterUnassignedSchemaPartitionSlots(req.getPartitionSlotsMap()); // Here we ensure that each StorageGroup has at least one SchemaRegion. // And if some StorageGroups own too many slots, extend SchemaRegion for them. // Map - Map unassignedSchemaPartitionSlotsCountMap = new ConcurrentHashMap<>(); + final Map unassignedSchemaPartitionSlotsCountMap = new ConcurrentHashMap<>(); unassignedSchemaPartitionSlotsMap.forEach( (storageGroup, unassignedSchemaPartitionSlots) -> unassignedSchemaPartitionSlotsCountMap.put( @@ -266,11 +266,11 @@ public SchemaPartitionResp getOrCreateSchemaPartition(GetOrCreateSchemaPartition return resp; } - Map assignedSchemaPartition; + final Map assignedSchemaPartition; try { assignedSchemaPartition = getLoadManager().allocateSchemaPartition(unassignedSchemaPartitionSlotsMap); - } catch (NoAvailableRegionGroupException e) { + } catch (final NoAvailableRegionGroupException e) { status = getConsensusManager().confirmLeader(); if (status.getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // The allocation might fail due to leadership change @@ -286,7 +286,7 @@ public SchemaPartitionResp getOrCreateSchemaPartition(GetOrCreateSchemaPartition } // Cache allocating result only if the current ConfigNode still holds its leadership - CreateSchemaPartitionPlan createPlan = new CreateSchemaPartitionPlan(); + final CreateSchemaPartitionPlan createPlan = new CreateSchemaPartitionPlan(); createPlan.setAssignedSchemaPartition(assignedSchemaPartition); status = consensusWritePartitionResult(createPlan); @@ -300,18 +300,18 @@ public SchemaPartitionResp getOrCreateSchemaPartition(GetOrCreateSchemaPartition resp = getSchemaPartition(req); if (!resp.isAllPartitionsExist()) { // Count the fail rate - AtomicInteger totalSlotNum = new AtomicInteger(); + final AtomicInteger totalSlotNum = new AtomicInteger(); req.getPartitionSlotsMap() .forEach((database, partitionSlots) -> totalSlotNum.addAndGet(partitionSlots.size())); - AtomicInteger unassignedSlotNum = new AtomicInteger(); - Map> unassignedSchemaPartitionSlotsMap = + final AtomicInteger unassignedSlotNum = new AtomicInteger(); + final Map> unassignedSchemaPartitionSlotsMap = partitionInfo.filterUnassignedSchemaPartitionSlots(req.getPartitionSlotsMap()); unassignedSchemaPartitionSlotsMap.forEach( (database, unassignedSchemaPartitionSlots) -> unassignedSlotNum.addAndGet(unassignedSchemaPartitionSlots.size())); - String errMsg = + final String errMsg = String.format( "Lacked %d/%d SchemaPartition allocation result in the response of getOrCreateSchemaPartition method", unassignedSlotNum.get(), totalSlotNum.get()); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 569a53227f6e..3025a6db2a43 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -458,18 +458,18 @@ public TSStatus setTimePartitionInterval( public synchronized void adjustMaxRegionGroupNum() { // Get all DatabaseSchemas // TODO - Map databaseSchemaMap = - getMatchedDatabaseSchemasByName(getDatabaseNames(null), false); + final Map databaseSchemaMap = + getMatchedDatabaseSchemasByName(getDatabaseNames(null), null); if (databaseSchemaMap.isEmpty()) { // Skip when there are no Databases return; } - int dataNodeNum = getNodeManager().getRegisteredDataNodeCount(); - int totalCpuCoreNum = getNodeManager().getDataNodeCpuCoreCount(); + final int dataNodeNum = getNodeManager().getRegisteredDataNodeCount(); + final int totalCpuCoreNum = getNodeManager().getDataNodeCpuCoreCount(); int databaseNum = databaseSchemaMap.size(); - for (TDatabaseSchema databaseSchema : databaseSchemaMap.values()) { + for (final TDatabaseSchema databaseSchema : databaseSchemaMap.values()) { if (!isDatabaseExist(databaseSchema.getName()) || databaseSchema.getName().equals(SchemaConstant.SYSTEM_DATABASE)) { // filter the pre deleted database and the system database @@ -477,8 +477,9 @@ public synchronized void adjustMaxRegionGroupNum() { } } - AdjustMaxRegionGroupNumPlan adjustMaxRegionGroupNumPlan = new AdjustMaxRegionGroupNumPlan(); - for (TDatabaseSchema databaseSchema : databaseSchemaMap.values()) { + final AdjustMaxRegionGroupNumPlan adjustMaxRegionGroupNumPlan = + new AdjustMaxRegionGroupNumPlan(); + for (final TDatabaseSchema databaseSchema : databaseSchemaMap.values()) { if (databaseSchema.getName().equals(SchemaConstant.SYSTEM_DATABASE)) { // filter the system database continue; @@ -488,17 +489,17 @@ public synchronized void adjustMaxRegionGroupNum() { // Adjust maxSchemaRegionGroupNum for each Database. // All Databases share the DataNodes equally. // The allocated SchemaRegionGroups will not be shrunk. - int allocatedSchemaRegionGroupCount; + final int allocatedSchemaRegionGroupCount; try { allocatedSchemaRegionGroupCount = getPartitionManager() .getRegionGroupCount(databaseSchema.getName(), TConsensusGroupType.SchemaRegion); - } catch (DatabaseNotExistsException e) { + } catch (final DatabaseNotExistsException e) { // ignore the pre deleted database continue; } - int maxSchemaRegionGroupNum = + final int maxSchemaRegionGroupNum = calcMaxRegionGroupNum( databaseSchema.getMinSchemaRegionGroupNum(), SCHEMA_REGION_PER_DATA_NODE, @@ -514,10 +515,10 @@ public synchronized void adjustMaxRegionGroupNum() { // Adjust maxDataRegionGroupNum for each Database. // All Databases share the DataNodes equally. // The allocated DataRegionGroups will not be shrunk. - int allocatedDataRegionGroupCount = + final int allocatedDataRegionGroupCount = getPartitionManager() .getRegionGroupCount(databaseSchema.getName(), TConsensusGroupType.DataRegion); - int maxDataRegionGroupNum = + final int maxDataRegionGroupNum = calcMaxRegionGroupNum( databaseSchema.getMinDataRegionGroupNum(), DATA_REGION_PER_DATA_NODE == 0 @@ -534,13 +535,13 @@ public synchronized void adjustMaxRegionGroupNum() { adjustMaxRegionGroupNumPlan.putEntry( databaseSchema.getName(), new Pair<>(maxSchemaRegionGroupNum, maxDataRegionGroupNum)); - } catch (DatabaseNotExistsException e) { + } catch (final DatabaseNotExistsException e) { LOGGER.warn("Adjust maxRegionGroupNum failed because Database doesn't exist", e); } } try { getConsensusManager().write(adjustMaxRegionGroupNumPlan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_WRITE_ERROR, e); } } @@ -631,7 +632,7 @@ public String getDatabaseNameByDevice(final IDeviceID deviceID) { * @return the matched DatabaseSchemas */ public Map getMatchedDatabaseSchemasByName( - final List rawPathList, final boolean isTableModel) { + final List rawPathList, final Boolean isTableModel) { final Map result = new ConcurrentHashMap<>(); clusterSchemaInfo .getMatchedDatabaseSchemasByName(rawPathList, isTableModel) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java index 26da0c8d5f5a..804be5986ecc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java @@ -765,9 +765,9 @@ private DataSet getSchemaNodeManagementPartition(ConfigPhysicalPlan req) { return schemaNodeManagementResp; } - private DataSet getRegionInfoList(ConfigPhysicalPlan req) { + private DataSet getRegionInfoList(final ConfigPhysicalPlan req) { final GetRegionInfoListPlan getRegionInfoListPlan = (GetRegionInfoListPlan) req; - TShowRegionReq showRegionReq = getRegionInfoListPlan.getShowRegionReq(); + final TShowRegionReq showRegionReq = getRegionInfoListPlan.getShowRegionReq(); if (showRegionReq != null && showRegionReq.isSetDatabases()) { final List storageGroups = showRegionReq.getDatabases(); final List matchedStorageGroups = diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index 85a427cfab9a..fedddc1d27f3 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -169,9 +169,9 @@ public TSStatus updateDataNode(UpdateDataNodePlan updateDataNodePlan) { * @return {@link TSStatusCode#SUCCESS_STATUS} if the new DatabasePartitionTable is created * successfully. */ - public TSStatus createDatabase(DatabaseSchemaPlan plan) { - String databaseName = plan.getSchema().getName(); - DatabasePartitionTable databasePartitionTable = new DatabasePartitionTable(databaseName); + public TSStatus createDatabase(final DatabaseSchemaPlan plan) { + final String databaseName = plan.getSchema().getName(); + final DatabasePartitionTable databasePartitionTable = new DatabasePartitionTable(databaseName); databasePartitionTables.put(databaseName, databasePartitionTable); return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index ca51c7c5dc78..4477d09c62a5 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -536,20 +536,15 @@ public TDatabaseSchema getMatchedDatabaseSchemaByName(final String database) * @return All DatabaseSchemas that matches to the specific Database patterns */ public Map getMatchedDatabaseSchemasByName( - final List rawPathList, final boolean isTableModel) { + final List rawPathList, final Boolean isTableModel) { final Map schemaMap = new HashMap<>(); databaseReadWriteLock.readLock().lock(); try { - final ConfigMTree mTree = isTableModel ? tableModelMTree : treeModelMTree; - for (final String rawPath : rawPathList) { - final PartialPath patternPath = getQualifiedDatabasePartialPath(rawPath); - final List matchedPaths = - mTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); - for (final PartialPath path : matchedPaths) { - schemaMap.put( - path.getFullPath(), - mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); - } + if (!Boolean.FALSE.equals(isTableModel)) { + enrichSchemaMap(rawPathList, tableModelMTree, schemaMap); + } + if (!Boolean.TRUE.equals(isTableModel)) { + enrichSchemaMap(rawPathList, treeModelMTree, schemaMap); } } catch (final MetadataException e) { LOGGER.warn(ERROR_NAME, e); @@ -559,24 +554,40 @@ public Map getMatchedDatabaseSchemasByName( return schemaMap; } + private void enrichSchemaMap( + final List rawPathList, + final ConfigMTree mTree, + final Map schemaMap) + throws MetadataException { + for (final String rawPath : rawPathList) { + final PartialPath patternPath = getQualifiedDatabasePartialPath(rawPath); + final List matchedPaths = + mTree.getMatchedDatabases(patternPath, ALL_MATCH_SCOPE, false); + for (final PartialPath path : matchedPaths) { + schemaMap.put( + path.getFullPath(), mTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); + } + } + } + /** * Only leader use this interface. Get the matched DatabaseSchemas. * * @param prefix prefix path such as root.a * @return All DatabaseSchemas that matches to the prefix path such as root.a.db1, root.a.db2 */ - public Map getMatchedDatabaseSchemasByPrefix(PartialPath prefix) { - Map schemaMap = new HashMap<>(); + public Map getMatchedDatabaseSchemasByPrefix(final PartialPath prefix) { + final Map schemaMap = new HashMap<>(); databaseReadWriteLock.readLock().lock(); try { - List matchedPaths = + final List matchedPaths = treeModelMTree.getMatchedDatabases(prefix, ALL_MATCH_SCOPE, true); - for (PartialPath path : matchedPaths) { + for (final PartialPath path : matchedPaths) { schemaMap.put( path.getFullPath(), treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); } - } catch (MetadataException e) { + } catch (final MetadataException e) { LOGGER.warn(ERROR_NAME, e); } finally { databaseReadWriteLock.readLock().unlock(); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java index c6ca00ab4632..1c468ebbce42 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java @@ -161,8 +161,8 @@ public void setStorageGroup(final PartialPath path) throws MetadataException { } /** Delete a database */ - public void deleteDatabase(PartialPath path) throws MetadataException { - IDatabaseMNode databaseMNode = getDatabaseNodeByDatabasePath(path); + public void deleteDatabase(final PartialPath path) throws MetadataException { + final IDatabaseMNode databaseMNode = getDatabaseNodeByDatabasePath(path); IConfigMNode cur = databaseMNode.getParent(); // Suppose current system has root.a.b.sg1, root.a.sg2, and delete root.a.b.sg1 // delete the database node sg1 diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java index 5c6178830c32..eb01dbaff9ea 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java @@ -174,9 +174,7 @@ import static org.apache.iotdb.db.queryengine.plan.execution.config.metadata.relational.CreateDBTask.TTL_KEY; import static org.apache.iotdb.db.queryengine.plan.relational.type.InternalTypeManager.getTSDataType; import static org.apache.iotdb.db.queryengine.plan.relational.type.TypeSignatureTranslator.toTypeSignature; -import static org.apache.iotdb.db.utils.constant.SqlConstant.ROOT; import static org.apache.tsfile.common.constant.TsFileConstant.PATH_SEPARATOR; -import static org.apache.tsfile.common.constant.TsFileConstant.PATH_SEPARATOR_CHAR; public class TableConfigTaskVisitor extends AstVisitor { @@ -225,7 +223,7 @@ private IConfigTask visitDatabaseStatement( accessControl.checkCanCreateDatabase(context.getSession().getUserName(), dbName); - schema.setName(ROOT + PATH_SEPARATOR_CHAR + dbName); + schema.setName(dbName); for (final Property property : node.getProperties()) { final String key = property.getName().getValue().toLowerCase(Locale.ENGLISH); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/AbstractAlterOrDropTableTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/AbstractAlterOrDropTableTask.java index 809bd8cbfd48..66312ea1441a 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/AbstractAlterOrDropTableTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/AbstractAlterOrDropTableTask.java @@ -19,8 +19,6 @@ package org.apache.iotdb.db.queryengine.plan.execution.config.metadata.relational; -import org.apache.iotdb.commons.utils.PathUtils; - abstract class AbstractAlterOrDropTableTask extends AbstractTableTask { protected final String queryId; @@ -32,7 +30,7 @@ protected AbstractAlterOrDropTableTask( final String tableName, final String queryId, final boolean tableIfExists) { - super(PathUtils.qualifyDatabaseName(database), tableName); + super(database, tableName); this.queryId = queryId; this.tableIfExists = tableIfExists; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java index 3d49790fc4f6..d2c31f1f3d54 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java @@ -305,9 +305,7 @@ private Map> getTablesInConfigNode( .fetchTables( tableInput.entrySet().stream() .collect( - Collectors.toMap( - entry -> PathUtils.qualifyDatabaseName(entry.getKey()), - entry -> entry.getValue().keySet()))); + Collectors.toMap(Map.Entry::getKey, entry -> entry.getValue().keySet()))); if (TSStatusCode.SUCCESS_STATUS.getStatusCode() == resp.getStatus().getCode()) { result = TsTableInternalRPCUtil.deserializeTsTableFetchResult(resp.getTableInfoMap()); } From 52b241b6fd4344dd24b89c5379888c0355a34d5c Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:25:34 +0800 Subject: [PATCH 10/71] refactor --- .../write/region/CreateRegionGroupsPlan.java | 39 ++++++++++--------- .../confignode/manager/load/LoadManager.java | 2 +- .../manager/load/balancer/RegionBalancer.java | 28 ++++++------- .../manager/partition/PartitionManager.java | 21 +++++----- .../persistence/partition/PartitionInfo.java | 4 +- .../persistence/schema/ClusterSchemaInfo.java | 4 +- .../persistence/schema/ConfigMTree.java | 16 ++++---- .../schema/ClusterSchemaInfoTest.java | 2 +- 8 files changed, 59 insertions(+), 57 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/region/CreateRegionGroupsPlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/region/CreateRegionGroupsPlan.java index 9cdec5f0d904..82677d745811 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/region/CreateRegionGroupsPlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/region/CreateRegionGroupsPlan.java @@ -50,7 +50,7 @@ public CreateRegionGroupsPlan() { this.regionGroupMap = new HashMap<>(); } - public CreateRegionGroupsPlan(ConfigPhysicalPlanType type) { + public CreateRegionGroupsPlan(final ConfigPhysicalPlanType type) { super(type); this.regionGroupMap = new HashMap<>(); } @@ -59,16 +59,17 @@ public Map> getRegionGroupMap() { return regionGroupMap; } - public void addRegionGroup(String database, TRegionReplicaSet regionReplicaSet) { + public void addRegionGroup(final String database, final TRegionReplicaSet regionReplicaSet) { regionGroupMap .computeIfAbsent(database, regionReplicaSets -> new ArrayList<>()) .add(regionReplicaSet); } - public void planLog(Logger logger) { - for (Map.Entry> regionGroupEntry : regionGroupMap.entrySet()) { - String database = regionGroupEntry.getKey(); - for (TRegionReplicaSet regionReplicaSet : regionGroupEntry.getValue()) { + public void planLog(final Logger logger) { + for (final Map.Entry> regionGroupEntry : + regionGroupMap.entrySet()) { + final String database = regionGroupEntry.getKey(); + for (final TRegionReplicaSet regionReplicaSet : regionGroupEntry.getValue()) { logger.info( "[CreateRegionGroups] RegionGroup: {}, belonged database: {}, on DataNodes: {}", regionReplicaSet.getRegionId(), @@ -80,24 +81,24 @@ public void planLog(Logger logger) { } } - public void serializeForProcedure(DataOutputStream stream) throws IOException { + public void serializeForProcedure(final DataOutputStream stream) throws IOException { this.serializeImpl(stream); } - public void deserializeForProcedure(ByteBuffer buffer) throws IOException { + public void deserializeForProcedure(final ByteBuffer buffer) throws IOException { // to remove the planType of ConfigPhysicalPlanType buffer.getShort(); this.deserializeImpl(buffer); } @Override - protected void serializeImpl(DataOutputStream stream) throws IOException { + protected void serializeImpl(final DataOutputStream stream) throws IOException { stream.writeShort(getType().getPlanType()); stream.writeInt(regionGroupMap.size()); - for (Entry> entry : regionGroupMap.entrySet()) { - String database = entry.getKey(); - List regionReplicaSets = entry.getValue(); + for (final Entry> entry : regionGroupMap.entrySet()) { + final String database = entry.getKey(); + final List regionReplicaSets = entry.getValue(); BasicStructureSerDeUtil.write(database, stream); stream.writeInt(regionReplicaSets.size()); regionReplicaSets.forEach( @@ -107,15 +108,15 @@ protected void serializeImpl(DataOutputStream stream) throws IOException { } @Override - protected void deserializeImpl(ByteBuffer buffer) throws IOException { - int databaseNum = buffer.getInt(); + protected void deserializeImpl(final ByteBuffer buffer) throws IOException { + final int databaseNum = buffer.getInt(); for (int i = 0; i < databaseNum; i++) { - String database = BasicStructureSerDeUtil.readString(buffer); + final String database = BasicStructureSerDeUtil.readString(buffer); regionGroupMap.put(database, new ArrayList<>()); - int regionReplicaSetNum = buffer.getInt(); + final int regionReplicaSetNum = buffer.getInt(); for (int j = 0; j < regionReplicaSetNum; j++) { - TRegionReplicaSet regionReplicaSet = + final TRegionReplicaSet regionReplicaSet = ThriftCommonsSerDeUtils.deserializeTRegionReplicaSet(buffer); regionGroupMap.get(database).add(regionReplicaSet); } @@ -123,7 +124,7 @@ protected void deserializeImpl(ByteBuffer buffer) throws IOException { } @Override - public boolean equals(Object o) { + public boolean equals(final Object o) { if (this == o) { return true; } @@ -133,7 +134,7 @@ public boolean equals(Object o) { if (!super.equals(o)) { return false; } - CreateRegionGroupsPlan that = (CreateRegionGroupsPlan) o; + final CreateRegionGroupsPlan that = (CreateRegionGroupsPlan) o; return Objects.equals(regionGroupMap, that.regionGroupMap); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java index ee9e7530f3d0..b2c1c9a41e97 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java @@ -99,7 +99,7 @@ protected void setHeartbeatService(IManager configManager, LoadCache loadCache) * @throws DatabaseNotExistsException If some specific StorageGroups don't exist */ public CreateRegionGroupsPlan allocateRegionGroups( - Map allotmentMap, TConsensusGroupType consensusGroupType) + final Map allotmentMap, final TConsensusGroupType consensusGroupType) throws NotEnoughDataNodeException, DatabaseNotExistsException { return regionBalancer.genRegionGroupsAllocationPlan(allotmentMap, consensusGroupType); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/RegionBalancer.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/RegionBalancer.java index 1b553eda4483..3528cbe13607 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/RegionBalancer.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/RegionBalancer.java @@ -77,42 +77,42 @@ public RegionBalancer(IManager configManager) { * @throws DatabaseNotExistsException When some StorageGroups don't exist */ public CreateRegionGroupsPlan genRegionGroupsAllocationPlan( - Map allotmentMap, TConsensusGroupType consensusGroupType) + final Map allotmentMap, final TConsensusGroupType consensusGroupType) throws NotEnoughDataNodeException, DatabaseNotExistsException { // Some new RegionGroups will have to occupy unknown DataNodes // if the number of online DataNodes is insufficient - List availableDataNodes = + final List availableDataNodes = getNodeManager().filterDataNodeThroughStatus(NodeStatus.Running, NodeStatus.Unknown); // Make sure the number of available DataNodes is enough for allocating new RegionGroups - for (String database : allotmentMap.keySet()) { - int replicationFactor = + for (final String database : allotmentMap.keySet()) { + final int replicationFactor = getClusterSchemaManager().getReplicationFactor(database, consensusGroupType); if (availableDataNodes.size() < replicationFactor) { throw new NotEnoughDataNodeException(availableDataNodes, replicationFactor); } } - CreateRegionGroupsPlan createRegionGroupsPlan = new CreateRegionGroupsPlan(); + final CreateRegionGroupsPlan createRegionGroupsPlan = new CreateRegionGroupsPlan(); // Only considering the specified ConsensusGroupType when doing allocation - List allocatedRegionGroups = + final List allocatedRegionGroups = getPartitionManager().getAllReplicaSets(consensusGroupType); - for (Map.Entry entry : allotmentMap.entrySet()) { - String database = entry.getKey(); - int allotment = entry.getValue(); - int replicationFactor = + for (final Map.Entry entry : allotmentMap.entrySet()) { + final String database = entry.getKey(); + final int allotment = entry.getValue(); + final int replicationFactor = getClusterSchemaManager().getReplicationFactor(database, consensusGroupType); // Only considering the specified Database when doing allocation - List databaseAllocatedRegionGroups = + final List databaseAllocatedRegionGroups = getPartitionManager().getAllReplicaSets(database, consensusGroupType); for (int i = 0; i < allotment; i++) { // Prepare input data - Map availableDataNodeMap = + final Map availableDataNodeMap = new HashMap<>(availableDataNodes.size()); - Map freeDiskSpaceMap = new HashMap<>(availableDataNodes.size()); + final Map freeDiskSpaceMap = new HashMap<>(availableDataNodes.size()); availableDataNodes.forEach( dataNodeConfiguration -> { int dataNodeId = dataNodeConfiguration.getLocation().getDataNodeId(); @@ -121,7 +121,7 @@ public CreateRegionGroupsPlan genRegionGroupsAllocationPlan( }); // Generate allocation plan - TRegionReplicaSet newRegionGroup = + final TRegionReplicaSet newRegionGroup = regionGroupAllocator.generateOptimalRegionReplicasDistribution( availableDataNodeMap, freeDiskSpaceMap, diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index d242c5a2c3b8..b7fe21a99dc2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -491,10 +491,10 @@ private TSStatus consensusWritePartitionResult(ConfigPhysicalPlan plan) { * are not enough DataNodes; STORAGE_GROUP_NOT_EXIST when some StorageGroups don't exist */ private TSStatus extendRegionGroupIfNecessary( - Map unassignedPartitionSlotsCountMap, - TConsensusGroupType consensusGroupType) { + final Map unassignedPartitionSlotsCountMap, + final TConsensusGroupType consensusGroupType) { - TSStatus result = new TSStatus(); + final TSStatus result = new TSStatus(); try { if (TConsensusGroupType.SchemaRegion.equals(consensusGroupType)) { @@ -532,17 +532,18 @@ private TSStatus extendRegionGroupIfNecessary( } private TSStatus customExtendRegionGroupIfNecessary( - Map unassignedPartitionSlotsCountMap, TConsensusGroupType consensusGroupType) + final Map unassignedPartitionSlotsCountMap, + final TConsensusGroupType consensusGroupType) throws DatabaseNotExistsException, NotEnoughDataNodeException { // Map - Map allotmentMap = new ConcurrentHashMap<>(); + final Map allotmentMap = new ConcurrentHashMap<>(); - for (Map.Entry entry : unassignedPartitionSlotsCountMap.entrySet()) { + for (final Map.Entry entry : unassignedPartitionSlotsCountMap.entrySet()) { final String database = entry.getKey(); - int minRegionGroupNum = + final int minRegionGroupNum = getClusterSchemaManager().getMinRegionGroupNum(database, consensusGroupType); - int allocatedRegionGroupCount = + final int allocatedRegionGroupCount = partitionInfo.getRegionGroupCount(database, consensusGroupType); // Extend RegionGroups until allocatedRegionGroupCount == minRegionGroupNum @@ -623,10 +624,10 @@ private TSStatus autoExtendRegionGroupIfNecessary( } private TSStatus generateAndAllocateRegionGroups( - Map allotmentMap, TConsensusGroupType consensusGroupType) + final Map allotmentMap, final TConsensusGroupType consensusGroupType) throws NotEnoughDataNodeException, DatabaseNotExistsException { if (!allotmentMap.isEmpty()) { - CreateRegionGroupsPlan createRegionGroupsPlan = + final CreateRegionGroupsPlan createRegionGroupsPlan = getLoadManager().allocateRegionGroups(allotmentMap, consensusGroupType); LOGGER.info("[CreateRegionGroups] Starting to create the following RegionGroups:"); createRegionGroupsPlan.planLog(LOGGER); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index fedddc1d27f3..fe4bd629b1a9 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -622,8 +622,8 @@ public String getRegionDatabase(TConsensusGroupId regionId) { * partitionSlotsMap */ public Map> filterUnassignedSchemaPartitionSlots( - Map> partitionSlotsMap) { - Map> result = new ConcurrentHashMap<>(); + final Map> partitionSlotsMap) { + final Map> result = new ConcurrentHashMap<>(); partitionSlotsMap.forEach( (database, partitionSlots) -> { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 4477d09c62a5..95d486dcf1f3 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -299,11 +299,11 @@ public TSStatus deleteDatabase(final DeleteDatabasePlan plan) { * @throws MetadataException if other exceptions happen */ public void checkDatabaseLimit() throws MetadataException { - int limit = COMMON_CONFIG.getDatabaseLimitThreshold(); + final int limit = COMMON_CONFIG.getDatabaseLimitThreshold(); if (limit > 0) { databaseReadWriteLock.readLock().lock(); try { - int count = + final int count = treeModelMTree.getDatabaseNum(ALL_MATCH_PATTERN, ALL_MATCH_SCOPE, false) - treeModelMTree.getDatabaseNum(SYSTEM_DATABASE_PATTERN, ALL_MATCH_SCOPE, false) + tableModelMTree.getDatabaseNum(ALL_MATCH_PATTERN, ALL_MATCH_SCOPE, false); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java index 1c468ebbce42..6843e1466a45 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java @@ -200,24 +200,24 @@ public List getBelongedDatabases(PartialPath pathPattern) throws Me * @return a list contains all database names under given path pattern */ public List getMatchedDatabases( - PartialPath pathPattern, PathPatternTree scope, boolean isPrefixMatch) + final PartialPath pathPattern, final PathPatternTree scope, final boolean isPrefixMatch) throws MetadataException { return collectDatabases(pathPattern, scope, isPrefixMatch, false); } private List collectDatabases( - PartialPath pathPattern, - PathPatternTree scope, - boolean isPrefixMatch, - boolean collectInternal) + final PartialPath pathPattern, + final PathPatternTree scope, + final boolean isPrefixMatch, + final boolean collectInternal) throws MetadataException { - List result = new LinkedList<>(); - try (DatabaseCollector collector = + final List result = new LinkedList<>(); + try (final DatabaseCollector collector = new DatabaseCollector, IConfigMNode>( root, pathPattern, store, isPrefixMatch, scope) { @Override - protected void collectDatabase(IDatabaseMNode node) { + protected void collectDatabase(final IDatabaseMNode node) { result.add(node.getPartialPath()); } }) { diff --git a/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfoTest.java b/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfoTest.java index 0e16ae342195..96dd26d9304f 100644 --- a/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfoTest.java +++ b/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfoTest.java @@ -112,7 +112,7 @@ public void testSnapshot() throws IOException, IllegalPathException { GetDatabasePlan getStorageGroupReq = new GetDatabasePlan( - Arrays.asList(PathUtils.splitPathToDetachedNodes("root.**")), ALL_MATCH_SCOPE); + Arrays.asList(PathUtils.splitPathToDetachedNodes("root.**")), ALL_MATCH_SCOPE, false); Map reloadResult = clusterSchemaInfo.getMatchedDatabaseSchemas(getStorageGroupReq).getSchemaMap(); Assert.assertEquals(testMap, reloadResult); From 891ae5d02918a5fa1212b6673fbb33849d6311af Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:42:57 +0800 Subject: [PATCH 11/71] Refactor --- .../confignode/manager/ProcedureManager.java | 7 +- .../persistence/partition/PartitionInfo.java | 4 +- .../persistence/schema/ClusterSchemaInfo.java | 74 +++++++------------ .../persistence/schema/ConfigMTree.java | 3 +- .../procedure/env/ConfigNodeProcedureEnv.java | 7 +- .../region/CreateRegionGroupsProcedure.java | 14 ++-- .../fetcher/cache/TableDeviceSchemaCache.java | 36 +++++---- .../impl/SchemaRegionMemoryImpl.java | 9 ++- .../apache/iotdb/commons/utils/PathUtils.java | 4 + 9 files changed, 79 insertions(+), 79 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java index 29a890a90ada..4664cdd652d7 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java @@ -912,11 +912,12 @@ public TSStatus migrateRegion(TMigrateRegionReq migrateRegionReq) { * {@link TSStatusCode#CREATE_REGION_ERROR} otherwise */ public TSStatus createRegionGroups( - TConsensusGroupType consensusGroupType, CreateRegionGroupsPlan createRegionGroupsPlan) { - CreateRegionGroupsProcedure procedure = + final TConsensusGroupType consensusGroupType, + final CreateRegionGroupsPlan createRegionGroupsPlan) { + final CreateRegionGroupsProcedure procedure = new CreateRegionGroupsProcedure(consensusGroupType, createRegionGroupsPlan); executor.submitProcedure(procedure); - TSStatus status = waitingProcedureFinished(procedure); + final TSStatus status = waitingProcedureFinished(procedure); if (status.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { return status; } else { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index fe4bd629b1a9..173e36a7d1bc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -121,6 +121,8 @@ public class PartitionInfo implements SnapshotProcessor { private final AtomicInteger nextRegionGroupId; // Map + // For tree model databases: The databaseName is a partial path's full path with "root." + // For table model databases: The databaseName is a full name without "root." private final Map databasePartitionTables; /** For Region-Maintainer. */ @@ -809,7 +811,7 @@ public int countDataNodeScatterWidth( * @return Number of Regions currently owned by the specific database * @throws DatabaseNotExistsException When the specific database doesn't exist */ - public int getRegionGroupCount(String database, TConsensusGroupType type) + public int getRegionGroupCount(final String database, final TConsensusGroupType type) throws DatabaseNotExistsException { if (!isDatabaseExisted(database)) { throw new DatabaseNotExistsException(database); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 95d486dcf1f3..ec1cf9c4dd74 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -835,102 +835,104 @@ public synchronized TemplateInfoResp checkTemplateSettable( // Before execute this method, checkTemplateSettable method should be invoked first and the whole // process must be synchronized - public synchronized TSStatus setSchemaTemplate(SetSchemaTemplatePlan setSchemaTemplatePlan) { - PartialPath path; + public synchronized TSStatus setSchemaTemplate( + final SetSchemaTemplatePlan setSchemaTemplatePlan) { + final PartialPath path; try { path = new PartialPath(setSchemaTemplatePlan.getPath()); - } catch (IllegalPathException e) { + } catch (final IllegalPathException e) { LOGGER.error(e.getMessage()); return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } try { - int templateId = templateTable.getTemplate(setSchemaTemplatePlan.getName()).getId(); + final int templateId = templateTable.getTemplate(setSchemaTemplatePlan.getName()).getId(); treeModelMTree.setTemplate(templateId, path); return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); - } catch (MetadataException e) { + } catch (final MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } } public synchronized TSStatus preSetSchemaTemplate( - PreSetSchemaTemplatePlan preSetSchemaTemplatePlan) { - PartialPath path; + final PreSetSchemaTemplatePlan preSetSchemaTemplatePlan) { + final PartialPath path; try { path = new PartialPath(preSetSchemaTemplatePlan.getPath()); - } catch (IllegalPathException e) { + } catch (final IllegalPathException e) { LOGGER.error(e.getMessage()); return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } try { - int templateId = templateTable.getTemplate(preSetSchemaTemplatePlan.getName()).getId(); + final int templateId = templateTable.getTemplate(preSetSchemaTemplatePlan.getName()).getId(); if (preSetSchemaTemplatePlan.isRollback()) { rollbackPreSetSchemaTemplate(templateId, path); } else { preSetSchemaTemplate(templateId, path); } return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); - } catch (MetadataException e) { + } catch (final MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } } - private void preSetSchemaTemplate(int templateId, PartialPath templateSetPath) + private void preSetSchemaTemplate(final int templateId, final PartialPath templateSetPath) throws MetadataException { templatePreSetTable.preSetTemplate(templateId, templateSetPath); treeModelMTree.setTemplate(templateId, templateSetPath); } - private void rollbackPreSetSchemaTemplate(int templateId, PartialPath templateSetPath) + private void rollbackPreSetSchemaTemplate(final int templateId, final PartialPath templateSetPath) throws MetadataException { try { treeModelMTree.unsetTemplate(templateId, templateSetPath); - } catch (MetadataException ignore) { + } catch (final MetadataException ignore) { // node not exists or not set template } templatePreSetTable.removeSetTemplate(templateId, templateSetPath); } public synchronized TSStatus commitSetSchemaTemplate( - CommitSetSchemaTemplatePlan commitSetSchemaTemplatePlan) { - PartialPath path; + final CommitSetSchemaTemplatePlan commitSetSchemaTemplatePlan) { + final PartialPath path; try { path = new PartialPath(commitSetSchemaTemplatePlan.getPath()); - } catch (IllegalPathException e) { + } catch (final IllegalPathException e) { LOGGER.error(e.getMessage()); return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } try { - int templateId = templateTable.getTemplate(commitSetSchemaTemplatePlan.getName()).getId(); + final int templateId = + templateTable.getTemplate(commitSetSchemaTemplatePlan.getName()).getId(); if (commitSetSchemaTemplatePlan.isRollback()) { rollbackCommitSetSchemaTemplate(templateId, path); } else { commitSetSchemaTemplate(templateId, path); } return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); - } catch (MetadataException e) { + } catch (final MetadataException e) { return RpcUtils.getStatus(e.getErrorCode(), e.getMessage()); } } - private void commitSetSchemaTemplate(int templateId, PartialPath templateSetPath) { + private void commitSetSchemaTemplate(final int templateId, final PartialPath templateSetPath) { templatePreSetTable.removeSetTemplate(templateId, templateSetPath); } - private void rollbackCommitSetSchemaTemplate(int templateId, PartialPath templateSetPath) - throws MetadataException { + private void rollbackCommitSetSchemaTemplate( + final int templateId, final PartialPath templateSetPath) throws MetadataException { treeModelMTree.unsetTemplate(templateId, templateSetPath); } - public PathInfoResp getPathsSetTemplate(GetPathsSetTemplatePlan getPathsSetTemplatePlan) { - PathInfoResp pathInfoResp = new PathInfoResp(); + public PathInfoResp getPathsSetTemplate(final GetPathsSetTemplatePlan getPathsSetTemplatePlan) { + final PathInfoResp pathInfoResp = new PathInfoResp(); TSStatus status; try { - String templateName = getPathsSetTemplatePlan.getName(); - PathPatternTree scope = getPathsSetTemplatePlan.getScope(); - int templateId; + final String templateName = getPathsSetTemplatePlan.getName(); + final PathPatternTree scope = getPathsSetTemplatePlan.getScope(); + final int templateId; if (templateName.equals(ONE_LEVEL_PATH_WILDCARD)) { templateId = ALL_TEMPLATE; } else { @@ -1072,26 +1074,6 @@ public TSStatus extendSchemaTemplate(ExtendSchemaTemplatePlan extendSchemaTempla } } - public Map getMatchedDatabaseSchemasByOneName( - final String[] databasePathPattern) { - final Map schemaMap = new HashMap<>(); - databaseReadWriteLock.readLock().lock(); - try { - final PartialPath patternPath = new PartialPath(databasePathPattern); - final List matchedPaths = treeModelMTree.getBelongedDatabases(patternPath); - for (final PartialPath path : matchedPaths) { - schemaMap.put( - path.getFullPath(), - treeModelMTree.getDatabaseNodeByPath(path).getAsMNode().getDatabaseSchema()); - } - } catch (final MetadataException e) { - LOGGER.warn(ERROR_NAME, e); - } finally { - databaseReadWriteLock.readLock().unlock(); - } - return schemaMap; - } - // region table management public TSStatus preCreateTable(final PreCreateTablePlan plan) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java index 6843e1466a45..3300463c71a1 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java @@ -185,7 +185,8 @@ public void deleteDatabase(final PartialPath path) throws MetadataException { * @param pathPattern a path pattern or a full path * @return a list contains all databases related to given path */ - public List getBelongedDatabases(PartialPath pathPattern) throws MetadataException { + public List getBelongedDatabases(final PartialPath pathPattern) + throws MetadataException { return collectDatabases(pathPattern, ALL_MATCH_SCOPE, false, true); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java index d9ec20316a75..19a89795ba78 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java @@ -369,7 +369,8 @@ public void createConfigNodeHeartbeatCache(int nodeId) { * @return Those RegionReplicas that failed to create */ public Map doRegionCreation( - TConsensusGroupType consensusGroupType, CreateRegionGroupsPlan createRegionGroupsPlan) { + final TConsensusGroupType consensusGroupType, + final CreateRegionGroupsPlan createRegionGroupsPlan) { // Prepare clientHandler DataNodeAsyncRequestContext clientHandler; @@ -395,8 +396,8 @@ public Map doRegionCreation( Map failedRegions = new HashMap<>(); for (List regionReplicaSets : createRegionGroupsPlan.getRegionGroupMap().values()) { - for (TRegionReplicaSet regionReplicaSet : regionReplicaSets) { - for (TDataNodeLocation dataNodeLocation : regionReplicaSet.getDataNodeLocations()) { + for (final TRegionReplicaSet regionReplicaSet : regionReplicaSets) { + for (final TDataNodeLocation dataNodeLocation : regionReplicaSet.getDataNodeLocations()) { if (responseMap.get(requestId).getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode()) { failedRegions .computeIfAbsent( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java index e573a35c2312..f741380c233f 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java @@ -69,17 +69,18 @@ public CreateRegionGroupsProcedure() { } public CreateRegionGroupsProcedure( - TConsensusGroupType consensusGroupType, CreateRegionGroupsPlan createRegionGroupsPlan) { + final TConsensusGroupType consensusGroupType, + final CreateRegionGroupsPlan createRegionGroupsPlan) { this.consensusGroupType = consensusGroupType; this.createRegionGroupsPlan = createRegionGroupsPlan; } @TestOnly public CreateRegionGroupsProcedure( - TConsensusGroupType consensusGroupType, - CreateRegionGroupsPlan createRegionGroupsPlan, - CreateRegionGroupsPlan persistPlan, - Map failedRegionReplicaSets) { + final TConsensusGroupType consensusGroupType, + final CreateRegionGroupsPlan createRegionGroupsPlan, + final CreateRegionGroupsPlan persistPlan, + final Map failedRegionReplicaSets) { this.consensusGroupType = consensusGroupType; this.createRegionGroupsPlan = createRegionGroupsPlan; this.persistPlan = persistPlan; @@ -87,7 +88,8 @@ public CreateRegionGroupsProcedure( } @Override - protected Flow executeFromState(ConfigNodeProcedureEnv env, CreateRegionGroupsState state) { + protected Flow executeFromState( + final ConfigNodeProcedureEnv env, final CreateRegionGroupsState state) { switch (state) { case CREATE_REGION_GROUPS: failedRegionReplicaSets = env.doRegionCreation(consensusGroupType, createRegionGroupsPlan); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java index 946210300591..a6b63d9c62c3 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java @@ -489,25 +489,29 @@ long getRequestCount() { return dualKeyCache.stats().requestCount(); } - // This database is with "root" - void invalidateLastCache(final @Nonnull String qualifiedDatabase) { - final String database = PathUtils.unQualifyDatabaseName(qualifiedDatabase); + void invalidateLastCache(final @Nonnull String database) { readWriteLock.writeLock().lock(); try { - dualKeyCache.update( - tableId -> - tableId.belongTo(database) - || Objects.isNull(tableId.getDatabase()) - && tableId.getTableName().startsWith(qualifiedDatabase), - deviceID -> true, - entry -> -entry.invalidateLastCache()); - dualKeyCache.update( - tableId -> - Objects.isNull(tableId.getDatabase()) - && qualifiedDatabase.startsWith(tableId.getTableName()), - deviceID -> deviceID.matchDatabaseName(qualifiedDatabase), - entry -> -entry.invalidateLastCache()); + if (PathUtils.isTableModelDatabase(database)) { + dualKeyCache.update( + tableId -> tableId.belongTo(database), + deviceID -> true, + entry -> -entry.invalidateLastCache()); + } else { + dualKeyCache.update( + tableId -> + Objects.isNull(tableId.getDatabase()) + && tableId.getTableName().startsWith(database), + deviceID -> true, + entry -> -entry.invalidateLastCache()); + dualKeyCache.update( + tableId -> + Objects.isNull(tableId.getDatabase()) + && database.startsWith(tableId.getTableName()), + deviceID -> deviceID.matchDatabaseName(database), + entry -> -entry.invalidateLastCache()); + } } finally { readWriteLock.writeLock().unlock(); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java index 2b484d64df90..589642fd89fc 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java @@ -192,6 +192,9 @@ public class SchemaRegionMemoryImpl implements ISchemaRegion { private final String storageGroupDirPath; private final String schemaRegionDirPath; + + // For table model db: without "root." + // For tree model db: with "root." private final String storageGroupFullPath; private final SchemaRegionId schemaRegionId; @@ -564,7 +567,7 @@ public void loadSnapshot(final File latestSnapshotRootDir) { snapshotStartTime = System.currentTimeMillis(); deviceAttributeCacheUpdater = - new DeviceAttributeCacheUpdater(regionStatistics, storageGroupFullPath.substring(5)); + new DeviceAttributeCacheUpdater(regionStatistics, storageGroupFullPath); deviceAttributeCacheUpdater.loadFromSnapshot(latestSnapshotRootDir); logger.info( "Device attribute remote updater snapshot loading of schemaRegion {} costs {}ms.", @@ -872,7 +875,7 @@ public void checkSchemaQuota(final String tableName, final List device schemaQuotaManager.check( (long) DataNodeTableCache.getInstance() - .getTable(storageGroupFullPath.substring(5), tableName) + .getTable(storageGroupFullPath, tableName) .getMeasurementNum() * notExistNum, notExistNum); @@ -1394,7 +1397,7 @@ public long countPathsUsingTemplate(final int templateId, final PathPatternTree public void createOrUpdateTableDevice(final CreateOrUpdateTableDeviceNode node) throws MetadataException { for (int i = 0; i < node.getDeviceIdList().size(); i++) { - final String databaseName = storageGroupFullPath.substring(5); + final String databaseName = storageGroupFullPath; final String tableName = node.getTableName(); final String[] deviceId = Arrays.stream(node.getDeviceIdList().get(i)) diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java index 005003d9b250..26ea7fb62c77 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java @@ -220,4 +220,8 @@ public static String unQualifyDatabaseName(String databaseName) { } return databaseName; } + + public static boolean isTableModelDatabase(final String databaseName) { + return !databaseName.startsWith("root."); + } } From 1d1cc324a15c20dbdd4ac66652de65f8ebfed4c4 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:48:31 +0800 Subject: [PATCH 12/71] fix --- .../impl/DataNodeInternalRPCServiceImpl.java | 4 +-- .../fetcher/cache/TableDeviceSchemaCache.java | 27 ++++++++++--------- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeInternalRPCServiceImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeInternalRPCServiceImpl.java index b1d2806cdc2a..492a379e6366 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeInternalRPCServiceImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeInternalRPCServiceImpl.java @@ -567,10 +567,10 @@ public TSStatus invalidateSchemaCache(final TInvalidateCacheReq req) { DataNodeSchemaLockManager.getInstance().takeWriteLock(SchemaLockType.VALIDATE_VS_DELETION); TreeDeviceSchemaCacheManager.getInstance().takeWriteLock(); try { + final String database = req.getFullPath(); // req.getFullPath() is a database path - ClusterTemplateManager.getInstance().invalid(req.getFullPath()); + ClusterTemplateManager.getInstance().invalid(database); // clear table related cache - final String database = req.getFullPath().substring(5); DataNodeTableCache.getInstance().invalid(database); tableDeviceSchemaCache.invalidate(database); LOGGER.info("Schema cache of {} has been invalidated", req.getFullPath()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java index a6b63d9c62c3..5fb056671b26 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/fetcher/cache/TableDeviceSchemaCache.java @@ -517,22 +517,23 @@ void invalidateLastCache(final @Nonnull String database) { } } - // This database is without "root" public void invalidate(final @Nonnull String database) { - final String qualifiedDatabase = PathUtils.qualifyDatabaseName(database); readWriteLock.writeLock().lock(); try { - dualKeyCache.invalidate( - tableId -> - tableId.belongTo(database) - || Objects.isNull(tableId.getDatabase()) - && tableId.getTableName().startsWith(qualifiedDatabase), - deviceID -> true); - dualKeyCache.invalidate( - tableId -> - Objects.isNull(tableId.getDatabase()) - && qualifiedDatabase.startsWith(tableId.getTableName()), - deviceID -> deviceID.matchDatabaseName(qualifiedDatabase)); + if (PathUtils.isTableModelDatabase(database)) { + dualKeyCache.invalidate(tableId -> tableId.belongTo(database), deviceID -> true); + } else { + dualKeyCache.invalidate( + tableId -> + Objects.isNull(tableId.getDatabase()) + && tableId.getTableName().startsWith(database), + deviceID -> true); + dualKeyCache.invalidate( + tableId -> + Objects.isNull(tableId.getDatabase()) + && database.startsWith(tableId.getTableName()), + deviceID -> deviceID.matchDatabaseName(database)); + } } finally { readWriteLock.writeLock().unlock(); } From 979647687b9cbb0277662d6b4a1aba051f27570d Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:58:38 +0800 Subject: [PATCH 13/71] Fix --- .../manager/schema/ClusterSchemaManager.java | 13 +++++++------ .../persistence/schema/ClusterSchemaInfo.java | 2 +- .../procedure/env/ConfigNodeProcedureEnv.java | 8 ++++---- .../config/metadata/relational/ShowDBTask.java | 4 ++-- 4 files changed, 14 insertions(+), 13 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 3025a6db2a43..01ce450f16a8 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -269,7 +269,8 @@ public TSStatus alterDatabase( } /** Delete DatabaseSchema. */ - public TSStatus deleteDatabase(DeleteDatabasePlan deleteDatabasePlan, boolean isGeneratedByPipe) { + public TSStatus deleteDatabase( + final DeleteDatabasePlan deleteDatabasePlan, final boolean isGeneratedByPipe) { TSStatus result; try { result = @@ -278,7 +279,7 @@ public TSStatus deleteDatabase(DeleteDatabasePlan deleteDatabasePlan, boolean is isGeneratedByPipe ? new PipeEnrichedPlan(deleteDatabasePlan) : deleteDatabasePlan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_WRITE_ERROR, e); result = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); result.setMessage(e.getMessage()); @@ -296,14 +297,14 @@ public TSStatus deleteDatabase(DeleteDatabasePlan deleteDatabasePlan, boolean is * * @return CountDatabaseResp */ - public CountDatabaseResp countMatchedDatabases(CountDatabasePlan countDatabasePlan) { + public CountDatabaseResp countMatchedDatabases(final CountDatabasePlan countDatabasePlan) { try { return (CountDatabaseResp) getConsensusManager().read(countDatabasePlan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_READ_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); - CountDatabaseResp response = new CountDatabaseResp(); + final CountDatabaseResp response = new CountDatabaseResp(); response.setStatus(res); return response; } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index ec1cf9c4dd74..976aa523c030 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -170,7 +170,7 @@ public TSStatus createDatabase(final DatabaseSchemaPlan plan) { try { // Set Database final TDatabaseSchema databaseSchema = plan.getSchema(); - final PartialPath partialPathName = PartialPath.getDatabasePath(databaseSchema.getName()); + final PartialPath partialPathName = getQualifiedDatabasePartialPath(databaseSchema.getName()); final ConfigMTree mTree = plan.getSchema().isIsTableModel() ? tableModelMTree : treeModelMTree; diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java index 19a89795ba78..f5cee035c2ca 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java @@ -137,8 +137,8 @@ public ConfigManager getConfigManager() { * @param isGeneratedByPipe whether the deletion is triggered by pipe request * @return tsStatus */ - public TSStatus deleteDatabaseConfig(String name, boolean isGeneratedByPipe) { - DeleteDatabasePlan deleteDatabasePlan = new DeleteDatabasePlan(name); + public TSStatus deleteDatabaseConfig(final String name, final boolean isGeneratedByPipe) { + final DeleteDatabasePlan deleteDatabasePlan = new DeleteDatabasePlan(name); return getClusterSchemaManager().deleteDatabase(deleteDatabasePlan, isGeneratedByPipe); } @@ -149,7 +149,7 @@ public TSStatus deleteDatabaseConfig(String name, boolean isGeneratedByPipe) { * @param deleteSgName database name */ public void preDeleteDatabase( - PreDeleteDatabasePlan.PreDeleteType preDeleteType, String deleteSgName) { + final PreDeleteDatabasePlan.PreDeleteType preDeleteType, final String deleteSgName) { getPartitionManager().preDeleteDatabase(deleteSgName, preDeleteType); } @@ -159,7 +159,7 @@ public void preDeleteDatabase( * @throws IOException IOE * @throws TException Thrift IOE */ - public boolean invalidateCache(String storageGroupName) throws IOException, TException { + public boolean invalidateCache(final String storageGroupName) throws IOException, TException { List allDataNodes = getNodeManager().getRegisteredDataNodes(); TInvalidateCacheReq invalidateCacheReq = new TInvalidateCacheReq(); invalidateCacheReq.setStorageGroup(true); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java index 575010752afd..b1cf77601fe6 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/ShowDBTask.java @@ -84,7 +84,7 @@ private static void buildTSBlockForNonDetails( final TsBlockBuilder builder = new TsBlockBuilder(outputDataTypes); for (final Map.Entry entry : storageGroupInfoMap.entrySet()) { - final String dbName = entry.getKey().substring(5); + final String dbName = entry.getKey(); if (!canSeenDB.apply(dbName)) { continue; } @@ -123,7 +123,7 @@ private static void buildTSBlockForDetails( final TsBlockBuilder builder = new TsBlockBuilder(outputDataTypes); for (final Map.Entry entry : storageGroupInfoMap.entrySet()) { - final String dbName = entry.getKey().substring(5); + final String dbName = entry.getKey(); if (!canSeenDB.apply(dbName)) { continue; } From acfa62deb2ce9e41a5734599cf4430039b483e8c Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 11:59:37 +0800 Subject: [PATCH 14/71] Update CreateTableTask.java --- .../execution/config/metadata/relational/CreateTableTask.java | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/CreateTableTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/CreateTableTask.java index 963440330463..45c5bfcf9f26 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/CreateTableTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/metadata/relational/CreateTableTask.java @@ -20,7 +20,6 @@ package org.apache.iotdb.db.queryengine.plan.execution.config.metadata.relational; import org.apache.iotdb.commons.schema.table.TsTable; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.queryengine.plan.execution.config.ConfigTaskResult; import org.apache.iotdb.db.queryengine.plan.execution.config.IConfigTask; import org.apache.iotdb.db.queryengine.plan.execution.config.executor.IConfigTaskExecutor; @@ -35,8 +34,7 @@ public class CreateTableTask implements IConfigTask { private final boolean ifNotExists; - public CreateTableTask(final TsTable table, String database, final boolean ifNotExists) { - database = PathUtils.qualifyDatabaseName(database); + public CreateTableTask(final TsTable table, final String database, final boolean ifNotExists) { this.table = table; this.database = database; this.ifNotExists = ifNotExists; From 33ed4bb062cd8ff3043ec018f08d2eb7882d8a5e Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 12:02:05 +0800 Subject: [PATCH 15/71] Update ClusterSchemaInfo.java --- .../iotdb/confignode/persistence/schema/ClusterSchemaInfo.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 976aa523c030..1d22d2825302 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -639,7 +639,7 @@ public int getMaxRegionGroupNum( try { final TDatabaseSchema storageGroupSchema = treeModelMTree - .getDatabaseNodeByDatabasePath(PartialPath.getDatabasePath(database)) + .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(database)) .getAsMNode() .getDatabaseSchema(); switch (consensusGroupType) { From e6047374bb3ed456d5d60da57944f8ede49b69c0 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 12:23:46 +0800 Subject: [PATCH 16/71] partial --- .../manager/schema/ClusterSchemaManager.java | 2 +- .../persistence/schema/ClusterSchemaInfo.java | 2 +- .../schema/table/CreateTableProcedure.java | 114 ------------------ .../state/schema/CreateTableState.java | 1 - 4 files changed, 2 insertions(+), 117 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 01ce450f16a8..ab77de28b618 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -603,7 +603,7 @@ public List getDatabaseNames(final Boolean isTableModel) { * @return The specific DatabaseSchema * @throws DatabaseNotExistsException When the specific Database doesn't exist */ - public TDatabaseSchema getDatabaseSchemaByName(String database) + public TDatabaseSchema getDatabaseSchemaByName(final String database) throws DatabaseNotExistsException { if (!isDatabaseExist(database)) { throw new DatabaseNotExistsException(database); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 1d22d2825302..df6e40fa7b45 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -518,7 +518,7 @@ public TDatabaseSchema getMatchedDatabaseSchemaByName(final String database) throws DatabaseNotExistsException { databaseReadWriteLock.readLock().lock(); try { - return treeModelMTree + return (PathUtils.isTableModelDatabase(database) ? tableModelMTree : treeModelMTree) .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(database)) .getAsMNode() .getDatabaseSchema(); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java index 26a71130e39a..56c2fb9c4fc3 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java @@ -19,16 +19,10 @@ package org.apache.iotdb.confignode.procedure.impl.schema.table; -import org.apache.iotdb.common.rpc.thrift.TConsensusGroupId; -import org.apache.iotdb.common.rpc.thrift.TDataNodeLocation; -import org.apache.iotdb.common.rpc.thrift.TRegionReplicaSet; import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.commons.exception.IoTDBException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; -import org.apache.iotdb.commons.path.PathPatternTree; import org.apache.iotdb.commons.schema.table.TsTable; -import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.consensus.request.write.table.CommitCreateTablePlan; import org.apache.iotdb.confignode.consensus.request.write.table.PreCreateTablePlan; import org.apache.iotdb.confignode.consensus.request.write.table.RollbackCreateTablePlan; @@ -38,30 +32,22 @@ import org.apache.iotdb.confignode.procedure.exception.ProcedureSuspendedException; import org.apache.iotdb.confignode.procedure.exception.ProcedureYieldException; import org.apache.iotdb.confignode.procedure.impl.StateMachineProcedure; -import org.apache.iotdb.confignode.procedure.impl.schema.DataNodeRegionTaskExecutor; import org.apache.iotdb.confignode.procedure.impl.schema.SchemaUtils; import org.apache.iotdb.confignode.procedure.state.schema.CreateTableState; import org.apache.iotdb.confignode.procedure.store.ProcedureType; import org.apache.iotdb.confignode.rpc.thrift.TDatabaseSchema; -import org.apache.iotdb.mpp.rpc.thrift.TCheckTimeSeriesExistenceReq; -import org.apache.iotdb.mpp.rpc.thrift.TCheckTimeSeriesExistenceResp; import org.apache.iotdb.rpc.TSStatusCode; import org.apache.tsfile.utils.ReadWriteIOUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.nio.ByteBuffer; -import java.util.ArrayList; -import java.util.List; import java.util.Map; import java.util.Objects; -import java.util.Set; -import static org.apache.iotdb.commons.conf.IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD; import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; import static org.apache.iotdb.rpc.TSStatusCode.TABLE_ALREADY_EXISTS; @@ -101,11 +87,6 @@ protected Flow executeFromState(final ConfigNodeProcedureEnv env, final CreateTa LOGGER.info("Pre release table {}.{}", database, table.getTableName()); preReleaseTable(env); break; - case VALIDATE_TIMESERIES_EXISTENCE: - LOGGER.info( - "Validate timeseries existence for table {}.{}", database, table.getTableName()); - validateTimeSeriesExistence(env); - break; case COMMIT_CREATE: LOGGER.info("Commit create table {}.{}", database, table.getTableName()); commitCreateTable(env); @@ -182,101 +163,6 @@ private void preReleaseTable(final ConfigNodeProcedureEnv env) { return; } - setNextState(CreateTableState.VALIDATE_TIMESERIES_EXISTENCE); - } - - private void validateTimeSeriesExistence(final ConfigNodeProcedureEnv env) { - final PathPatternTree patternTree = new PathPatternTree(); - final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); - final PartialPath path; - try { - path = new PartialPath(new String[] {ROOT, database.substring(5), table.getTableName()}); - patternTree.appendPathPattern(path); - patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); - patternTree.serialize(dataOutputStream); - } catch (final IOException e) { - LOGGER.warn("failed to serialize request for table {}.{}", database, table.getTableName(), e); - } - final ByteBuffer patternTreeBytes = ByteBuffer.wrap(byteArrayOutputStream.toByteArray()); - - final Map relatedSchemaRegionGroup = - env.getConfigManager().getRelatedSchemaRegionGroup(patternTree); - - if (relatedSchemaRegionGroup.isEmpty()) { - setNextState(CreateTableState.COMMIT_CREATE); - return; - } - - final List respList = new ArrayList<>(); - DataNodeRegionTaskExecutor - regionTask = - new DataNodeRegionTaskExecutor< - TCheckTimeSeriesExistenceReq, TCheckTimeSeriesExistenceResp>( - env, - relatedSchemaRegionGroup, - false, - CnToDnAsyncRequestType.CHECK_TIMESERIES_EXISTENCE, - ((dataNodeLocation, consensusGroupIdList) -> - new TCheckTimeSeriesExistenceReq(patternTreeBytes, consensusGroupIdList))) { - - @Override - protected List processResponseOfOneDataNode( - final TDataNodeLocation dataNodeLocation, - final List consensusGroupIdList, - final TCheckTimeSeriesExistenceResp response) { - respList.add(response); - final List failedRegionList = new ArrayList<>(); - if (response.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { - return failedRegionList; - } - - if (response.getStatus().getCode() == TSStatusCode.MULTIPLE_ERROR.getStatusCode()) { - final List subStatus = response.getStatus().getSubStatus(); - for (int i = 0; i < subStatus.size(); i++) { - if (subStatus.get(i).getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode() - && subStatus.get(i).getCode() - != TSStatusCode.TIMESERIES_ALREADY_EXIST.getStatusCode()) { - failedRegionList.add(consensusGroupIdList.get(i)); - } - } - } else { - failedRegionList.addAll(consensusGroupIdList); - } - return failedRegionList; - } - - @Override - protected void onAllReplicasetFailure( - final TConsensusGroupId consensusGroupId, - final Set dataNodeLocationSet) { - setFailure( - new ProcedureException( - new MetadataException( - String.format( - "Create table %s.%s failed when [check timeseries existence on DataNode] because all replicaset of schemaRegion %s failed. %s", - database, - table.getTableName(), - consensusGroupId.id, - dataNodeLocationSet)))); - interruptTask(); - } - }; - regionTask.execute(); - if (isFailed()) { - return; - } - - for (final TCheckTimeSeriesExistenceResp resp : respList) { - if (resp.isExists()) { - setFailure( - new ProcedureException( - new MetadataException( - String.format( - "Timeseries already exists under root.%s.%s", - database, table.getTableName())))); - } - } setNextState(CreateTableState.COMMIT_CREATE); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/state/schema/CreateTableState.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/state/schema/CreateTableState.java index 9d09a09cfb88..be765853ed05 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/state/schema/CreateTableState.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/state/schema/CreateTableState.java @@ -23,7 +23,6 @@ public enum CreateTableState { CHECK_TABLE_EXISTENCE, PRE_CREATE, PRE_RELEASE, - VALIDATE_TIMESERIES_EXISTENCE, COMMIT_CREATE, COMMIT_RELEASE, } From cc0d808bf7c3d31d203de5024b645fd75b963c98 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 14:29:20 +0800 Subject: [PATCH 17/71] Fix --- .../NoAvailableRegionGroupException.java | 2 +- .../manager/partition/PartitionManager.java | 6 ++++-- .../persistence/partition/PartitionInfo.java | 17 ++++++++++++----- .../thrift/ConfigNodeRPCServiceProcessor.java | 9 ++++----- .../persistence/PartitionInfoTest.java | 16 ++++++++-------- .../executor/ClusterConfigTaskExecutor.java | 2 +- .../src/main/thrift/confignode.thrift | 1 + 7 files changed, 31 insertions(+), 22 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/exception/NoAvailableRegionGroupException.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/exception/NoAvailableRegionGroupException.java index d2309c5e2114..589cd481ded1 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/exception/NoAvailableRegionGroupException.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/exception/NoAvailableRegionGroupException.java @@ -26,7 +26,7 @@ public class NoAvailableRegionGroupException extends ConfigNodeException { private static final String SCHEMA_REGION_GROUP = "SchemaRegionGroup"; private static final String DATA_REGION_GROUP = "DataRegionGroup"; - public NoAvailableRegionGroupException(TConsensusGroupType regionGroupType) { + public NoAvailableRegionGroupException(final TConsensusGroupType regionGroupType) { super( String.format( "There are no available %s RegionGroups currently, " diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index b7fe21a99dc2..72ddcac1acad 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -897,7 +897,8 @@ public long getAssignedTimePartitionSlotsCount(String database) { * are unavailable currently */ public List> getSortedRegionGroupSlotsCounter( - String database, TConsensusGroupType type) throws NoAvailableRegionGroupException { + final String database, final TConsensusGroupType type) + throws NoAvailableRegionGroupException { // Collect static data List> regionGroupSlotsCounter = partitionInfo.getRegionGroupSlotsCounter(database, type); @@ -905,7 +906,8 @@ public List> getSortedRegionGroupSlotsCounter( // Filter RegionGroups that have Disabled status List> result = new ArrayList<>(); for (Pair slotsCounter : regionGroupSlotsCounter) { - RegionGroupStatus status = getLoadManager().getRegionGroupStatus(slotsCounter.getRight()); + final RegionGroupStatus status = + getLoadManager().getRegionGroupStatus(slotsCounter.getRight()); if (!RegionGroupStatus.Disabled.equals(status)) { result.add(slotsCounter); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index 173e36a7d1bc..b17cd73fc0c1 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -29,6 +29,7 @@ import org.apache.iotdb.commons.partition.DataPartitionTable; import org.apache.iotdb.commons.partition.SchemaPartitionTable; import org.apache.iotdb.commons.snapshot.SnapshotProcessor; +import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.confignode.consensus.request.read.partition.CountTimeSlotListPlan; import org.apache.iotdb.confignode.consensus.request.read.partition.GetDataPartitionPlan; import org.apache.iotdb.confignode.consensus.request.read.partition.GetSchemaPartitionPlan; @@ -527,19 +528,25 @@ public DataSet getSchemaNodeManagementPartition(List matchedDatabases) { } /** Get Region information. */ - public DataSet getRegionInfoList(GetRegionInfoListPlan regionsInfoPlan) { - RegionInfoListResp regionResp = new RegionInfoListResp(); - List regionInfoList = new Vector<>(); + public DataSet getRegionInfoList(final GetRegionInfoListPlan regionsInfoPlan) { + final RegionInfoListResp regionResp = new RegionInfoListResp(); + final List regionInfoList = new Vector<>(); if (databasePartitionTables.isEmpty()) { regionResp.setStatus(RpcUtils.getStatus(TSStatusCode.SUCCESS_STATUS)); regionResp.setRegionInfoList(new ArrayList<>()); return regionResp; } - TShowRegionReq showRegionReq = regionsInfoPlan.getShowRegionReq(); + final TShowRegionReq showRegionReq = regionsInfoPlan.getShowRegionReq(); final List databases = showRegionReq != null ? showRegionReq.getDatabases() : null; + final Boolean isTableModel = + showRegionReq != null + ? showRegionReq.isSetIsTableModel() && showRegionReq.isIsTableModel() + : null; databasePartitionTables.forEach( (database, databasePartitionTable) -> { - if (databases != null && !databases.contains(database)) { + if (databases != null && !databases.contains(database) + || Boolean.TRUE.equals(isTableModel) && !PathUtils.isTableModelDatabase(database) + || Boolean.FALSE.equals(isTableModel) && PathUtils.isTableModelDatabase(database)) { return; } regionInfoList.addAll(databasePartitionTable.getRegionInfoList(regionsInfoPlan)); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index bd404234ed44..0e0dc775ff89 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -990,11 +990,10 @@ public TGetDataNodeLocationsResp getRunningDataNodeLocations() { } @Override - public TShowRegionResp showRegion(TShowRegionReq showRegionReq) { - // TODO: Model - GetRegionInfoListPlan getRegionInfoListPlan = new GetRegionInfoListPlan(showRegionReq); - RegionInfoListResp dataSet = configManager.showRegion(getRegionInfoListPlan); - TShowRegionResp showRegionResp = new TShowRegionResp(); + public TShowRegionResp showRegion(final TShowRegionReq showRegionReq) { + final GetRegionInfoListPlan getRegionInfoListPlan = new GetRegionInfoListPlan(showRegionReq); + final RegionInfoListResp dataSet = configManager.showRegion(getRegionInfoListPlan); + final TShowRegionResp showRegionResp = new TShowRegionResp(); showRegionResp.setStatus(dataSet.getStatus()); showRegionResp.setRegionInfoList(dataSet.getRegionInfoList()); return showRegionResp; diff --git a/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/PartitionInfoTest.java b/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/PartitionInfoTest.java index c15cefff6579..8a605628aafa 100644 --- a/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/PartitionInfoTest.java +++ b/iotdb-core/confignode/src/test/java/org/apache/iotdb/confignode/persistence/PartitionInfoTest.java @@ -203,7 +203,7 @@ public void testShowRegion() { // Create a SchemaRegion CreateRegionGroupsPlan createRegionGroupsPlan = new CreateRegionGroupsPlan(); - TRegionReplicaSet schemaRegionReplicaSet = + final TRegionReplicaSet schemaRegionReplicaSet = generateTRegionReplicaSet( testFlag.SchemaPartition.getFlag(), generateTConsensusGroupId( @@ -213,7 +213,7 @@ public void testShowRegion() { // Create a DataRegion createRegionGroupsPlan = new CreateRegionGroupsPlan(); - TRegionReplicaSet dataRegionReplicaSet = + final TRegionReplicaSet dataRegionReplicaSet = generateTRegionReplicaSet( testFlag.DataPartition.getFlag(), generateTConsensusGroupId( @@ -221,11 +221,11 @@ public void testShowRegion() { createRegionGroupsPlan.addRegionGroup("root.test" + i, dataRegionReplicaSet); partitionInfo.createRegionGroups(createRegionGroupsPlan); } - GetRegionInfoListPlan regionReq = new GetRegionInfoListPlan(); - TShowRegionReq showRegionReq = new TShowRegionReq(); + final GetRegionInfoListPlan regionReq = new GetRegionInfoListPlan(); + final TShowRegionReq showRegionReq = new TShowRegionReq(); showRegionReq.setConsensusGroupType(null); regionReq.setShowRegionReq(showRegionReq); - RegionInfoListResp regionInfoList1 = + final RegionInfoListResp regionInfoList1 = (RegionInfoListResp) partitionInfo.getRegionInfoList(regionReq); Assert.assertEquals(20, regionInfoList1.getRegionInfoList().size()); regionInfoList1 @@ -233,7 +233,7 @@ public void testShowRegion() { .forEach((regionInfo) -> Assert.assertEquals("127.0.0.1", regionInfo.getClientRpcIp())); showRegionReq.setConsensusGroupType(TConsensusGroupType.SchemaRegion); - RegionInfoListResp regionInfoList2 = + final RegionInfoListResp regionInfoList2 = (RegionInfoListResp) partitionInfo.getRegionInfoList(regionReq); Assert.assertEquals(10, regionInfoList2.getRegionInfoList().size()); regionInfoList2 @@ -244,7 +244,7 @@ public void testShowRegion() { TConsensusGroupType.SchemaRegion, regionInfo.getConsensusGroupId().getType())); showRegionReq.setConsensusGroupType(TConsensusGroupType.DataRegion); - RegionInfoListResp regionInfoList3 = + final RegionInfoListResp regionInfoList3 = (RegionInfoListResp) partitionInfo.getRegionInfoList(regionReq); Assert.assertEquals(10, regionInfoList3.getRegionInfoList().size()); regionInfoList3 @@ -255,7 +255,7 @@ public void testShowRegion() { TConsensusGroupType.DataRegion, regionInfo.getConsensusGroupId().getType())); showRegionReq.setConsensusGroupType(null); showRegionReq.setDatabases(Collections.singletonList("root.test1")); - RegionInfoListResp regionInfoList4 = + final RegionInfoListResp regionInfoList4 = (RegionInfoListResp) partitionInfo.getRegionInfoList(regionReq); Assert.assertEquals(10, regionInfoList4.getRegionInfoList().size()); regionInfoList4 diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 93b3e5619ba8..47eeed5a26a6 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -1476,7 +1476,7 @@ public SettableFuture showRegion( final ShowRegionStatement showRegionStatement, final boolean isTableModel) { final SettableFuture future = SettableFuture.create(); TShowRegionResp showRegionResp = new TShowRegionResp(); - final TShowRegionReq showRegionReq = new TShowRegionReq(); + final TShowRegionReq showRegionReq = new TShowRegionReq().setIsTableModel(isTableModel); showRegionReq.setConsensusGroupType(showRegionStatement.getRegionType()); if (showRegionStatement.getStorageGroups() == null) { showRegionReq.setDatabases(null); diff --git a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift index abe7faa3c892..518d09c6720a 100644 --- a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift +++ b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift @@ -623,6 +623,7 @@ struct TShowDatabaseResp { struct TShowRegionReq { 1: optional common.TConsensusGroupType consensusGroupType; 2: optional list databases + 3: optional bool isTableModel } struct TRegionInfo { From 7654d3991c8107324d5e68f4a8220497e7dea1a8 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 14:47:15 +0800 Subject: [PATCH 18/71] Fix --- .../confignode/manager/load/LoadManager.java | 2 +- .../load/balancer/PartitionBalancer.java | 18 ++++----- .../manager/partition/PartitionManager.java | 17 +++++---- .../persistence/schema/ClusterSchemaInfo.java | 4 +- .../region/CreateRegionGroupsProcedure.java | 37 ++++++++++--------- ...GeneralRegionAttributeSecurityService.java | 6 ++- 6 files changed, 44 insertions(+), 40 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java index b2c1c9a41e97..bb4c6fa068f5 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java @@ -111,7 +111,7 @@ public CreateRegionGroupsPlan allocateRegionGroups( * @return Map, the allocating result */ public Map allocateSchemaPartition( - Map> unassignedSchemaPartitionSlotsMap) + final Map> unassignedSchemaPartitionSlotsMap) throws NoAvailableRegionGroupException { return partitionBalancer.allocateSchemaPartition(unassignedSchemaPartitionSlotsMap); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/PartitionBalancer.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/PartitionBalancer.java index 9b9b79b61159..2173563c704f 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/PartitionBalancer.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/PartitionBalancer.java @@ -71,31 +71,31 @@ public PartitionBalancer(IManager configManager) { * @return Map, the allocating result */ public Map allocateSchemaPartition( - Map> unassignedSchemaPartitionSlotsMap) + final Map> unassignedSchemaPartitionSlotsMap) throws NoAvailableRegionGroupException { - Map result = new HashMap<>(); + final Map result = new HashMap<>(); - for (Map.Entry> slotsMapEntry : + for (final Map.Entry> slotsMapEntry : unassignedSchemaPartitionSlotsMap.entrySet()) { final String database = slotsMapEntry.getKey(); final List unassignedPartitionSlots = slotsMapEntry.getValue(); // Filter available SchemaRegionGroups and // sort them by the number of allocated SchemaPartitions - BalanceTreeMap counter = new BalanceTreeMap<>(); - List> regionSlotsCounter = + final BalanceTreeMap counter = new BalanceTreeMap<>(); + final List> regionSlotsCounter = getPartitionManager() .getSortedRegionGroupSlotsCounter(database, TConsensusGroupType.SchemaRegion); - for (Pair pair : regionSlotsCounter) { + for (final Pair pair : regionSlotsCounter) { counter.put(pair.getRight(), pair.getLeft().intValue()); } // Enumerate SeriesPartitionSlot - Map schemaPartitionMap = new HashMap<>(); - for (TSeriesPartitionSlot seriesPartitionSlot : unassignedPartitionSlots) { + final Map schemaPartitionMap = new HashMap<>(); + for (final TSeriesPartitionSlot seriesPartitionSlot : unassignedPartitionSlots) { // Greedy allocation: allocate the unassigned SchemaPartition to // the RegionGroup whose allocated SchemaPartitions is the least - TConsensusGroupId consensusGroupId = counter.getKeyWithMinValue(); + final TConsensusGroupId consensusGroupId = counter.getKeyWithMinValue(); schemaPartitionMap.put(seriesPartitionSlot, consensusGroupId); counter.put(consensusGroupId, counter.get(consensusGroupId) + 1); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index 72ddcac1acad..6bc470cff260 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -556,11 +556,12 @@ private TSStatus customExtendRegionGroupIfNecessary( } private TSStatus autoExtendRegionGroupIfNecessary( - Map unassignedPartitionSlotsCountMap, TConsensusGroupType consensusGroupType) + final Map unassignedPartitionSlotsCountMap, + final TConsensusGroupType consensusGroupType) throws NotEnoughDataNodeException, DatabaseNotExistsException { // Map - Map allotmentMap = new ConcurrentHashMap<>(); + final Map allotmentMap = new ConcurrentHashMap<>(); for (Map.Entry entry : unassignedPartitionSlotsCountMap.entrySet()) { final String database = entry.getKey(); @@ -578,7 +579,7 @@ private TSStatus autoExtendRegionGroupIfNecessary( /* RegionGroup extension is required in the following cases */ // 1. The number of current RegionGroup of the Database is less than the minimum number - int minRegionGroupNum = + final int minRegionGroupNum = getClusterSchemaManager().getMinRegionGroupNum(database, consensusGroupType); if (allocatedRegionGroupCount < minRegionGroupNum // Ensure the number of RegionGroups is enough @@ -601,7 +602,7 @@ private TSStatus autoExtendRegionGroupIfNecessary( // The delta is equal to the smallest integer solution that satisfies the inequality: // slotCount / (allocatedRegionGroupCount + delta) < maxSlotCount / maxRegionGroupNum - int delta = + final int delta = Math.min( (int) (maxRegionGroupNum - allocatedRegionGroupCount), Math.max( @@ -900,12 +901,12 @@ public List> getSortedRegionGroupSlotsCounter( final String database, final TConsensusGroupType type) throws NoAvailableRegionGroupException { // Collect static data - List> regionGroupSlotsCounter = + final List> regionGroupSlotsCounter = partitionInfo.getRegionGroupSlotsCounter(database, type); // Filter RegionGroups that have Disabled status - List> result = new ArrayList<>(); - for (Pair slotsCounter : regionGroupSlotsCounter) { + final List> result = new ArrayList<>(); + for (final Pair slotsCounter : regionGroupSlotsCounter) { final RegionGroupStatus status = getLoadManager().getRegionGroupStatus(slotsCounter.getRight()); if (!RegionGroupStatus.Disabled.equals(status)) { @@ -917,7 +918,7 @@ public List> getSortedRegionGroupSlotsCounter( throw new NoAvailableRegionGroupException(type); } - Map regionGroupStatusMap = + final Map regionGroupStatusMap = getLoadManager() .getRegionGroupStatus(result.stream().map(Pair::getRight).collect(Collectors.toList())); result.sort( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index df6e40fa7b45..86d7aedf624b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -607,7 +607,7 @@ public int getMinRegionGroupNum( databaseReadWriteLock.readLock().lock(); try { final TDatabaseSchema storageGroupSchema = - treeModelMTree + (PathUtils.isTableModelDatabase(database) ? tableModelMTree : treeModelMTree) .getDatabaseNodeByDatabasePath(PartialPath.getDatabasePath(database)) .getAsMNode() .getDatabaseSchema(); @@ -638,7 +638,7 @@ public int getMaxRegionGroupNum( databaseReadWriteLock.readLock().lock(); try { final TDatabaseSchema storageGroupSchema = - treeModelMTree + (PathUtils.isTableModelDatabase(database) ? tableModelMTree : treeModelMTree) .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(database)) .getAsMNode() .getDatabaseSchema(); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java index f741380c233f..2bcaee129d58 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/region/CreateRegionGroupsProcedure.java @@ -97,7 +97,7 @@ protected Flow executeFromState( break; case SHUNT_REGION_REPLICAS: persistPlan = new CreateRegionGroupsPlan(); - OfferRegionMaintainTasksPlan offerPlan = new OfferRegionMaintainTasksPlan(); + final OfferRegionMaintainTasksPlan offerPlan = new OfferRegionMaintainTasksPlan(); // Filter those RegionGroups that created successfully createRegionGroupsPlan .getRegionGroupMap() @@ -114,7 +114,7 @@ protected Flow executeFromState( "[CreateRegionGroups] All replicas of RegionGroup: {} are created successfully!", regionReplicaSet.getRegionId()); } else { - TRegionReplicaSet failedRegionReplicas = + final TRegionReplicaSet failedRegionReplicas = failedRegionReplicaSets.get(regionReplicaSet.getRegionId()); if (failedRegionReplicas.getDataNodeLocationsSize() @@ -163,15 +163,15 @@ protected Flow executeFromState( env.persistRegionGroup(persistPlan); try { env.getConfigManager().getConsensusManager().write(offerPlan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn("Failed in the write API executing the consensus layer due to: ", e); } setNextState(CreateRegionGroupsState.ACTIVATE_REGION_GROUPS); break; case ACTIVATE_REGION_GROUPS: - long currentTime = System.nanoTime(); + final long currentTime = System.nanoTime(); // Build RegionGroupCache immediately to make these successfully built RegionGroup available - Map>> + final Map>> activateRegionGroupMap = new TreeMap<>(); createRegionGroupsPlan .getRegionGroupMap() @@ -184,13 +184,14 @@ protected Flow executeFromState( if (failedRegionReplicas == null || failedRegionReplicas.getDataNodeLocationsSize() <= (regionReplicaSet.getDataNodeLocationsSize() - 1) / 2) { - Set failedDataNodeIds = + final Set failedDataNodeIds = failedRegionReplicas == null ? new TreeSet<>() : failedRegionReplicas.getDataNodeLocations().stream() .map(TDataNodeLocation::getDataNodeId) .collect(Collectors.toSet()); - Map activateSampleMap = new TreeMap<>(); + final Map activateSampleMap = + new TreeMap<>(); regionReplicaSet .getDataNodeLocations() .forEach( @@ -232,18 +233,18 @@ protected Flow executeFromState( @Override protected void rollbackState( - ConfigNodeProcedureEnv configNodeProcedureEnv, - CreateRegionGroupsState createRegionGroupsState) { + final ConfigNodeProcedureEnv configNodeProcedureEnv, + final CreateRegionGroupsState createRegionGroupsState) { // Do nothing } @Override - protected CreateRegionGroupsState getState(int stateId) { + protected CreateRegionGroupsState getState(final int stateId) { return CreateRegionGroupsState.values()[stateId]; } @Override - protected int getStateId(CreateRegionGroupsState createRegionGroupsState) { + protected int getStateId(final CreateRegionGroupsState createRegionGroupsState) { return createRegionGroupsState.ordinal(); } @@ -253,7 +254,7 @@ protected CreateRegionGroupsState getInitialState() { } @Override - public void serialize(DataOutputStream stream) throws IOException { + public void serialize(final DataOutputStream stream) throws IOException { // Must serialize CREATE_REGION_GROUPS.getTypeCode() firstly stream.writeShort(ProcedureType.CREATE_REGION_GROUPS.getTypeCode()); super.serialize(stream); @@ -269,7 +270,7 @@ public void serialize(DataOutputStream stream) throws IOException { } @Override - public void deserialize(ByteBuffer byteBuffer) { + public void deserialize(final ByteBuffer byteBuffer) { super.deserialize(byteBuffer); this.consensusGroupType = TConsensusGroupType.findByValue(byteBuffer.getInt()); try { @@ -277,30 +278,30 @@ public void deserialize(ByteBuffer byteBuffer) { failedRegionReplicaSets.clear(); int failedRegionsSize = byteBuffer.getInt(); while (failedRegionsSize-- > 0) { - TConsensusGroupId groupId = + final TConsensusGroupId groupId = ThriftCommonsSerDeUtils.deserializeTConsensusGroupId(byteBuffer); - TRegionReplicaSet replica = + final TRegionReplicaSet replica = ThriftCommonsSerDeUtils.deserializeTRegionReplicaSet(byteBuffer); failedRegionReplicaSets.put(groupId, replica); } if (byteBuffer.hasRemaining()) { persistPlan.deserializeForProcedure(byteBuffer); } - } catch (Exception e) { + } catch (final Exception e) { LOGGER.error("Deserialize meets error in CreateRegionGroupsProcedure", e); throw new RuntimeException(e); } } @Override - public boolean equals(Object o) { + public boolean equals(final Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } - CreateRegionGroupsProcedure that = (CreateRegionGroupsProcedure) o; + final CreateRegionGroupsProcedure that = (CreateRegionGroupsProcedure) o; return consensusGroupType == that.consensusGroupType && createRegionGroupsPlan.equals(that.createRegionGroupsPlan) && persistPlan.equals(that.persistPlan) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/attribute/update/GeneralRegionAttributeSecurityService.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/attribute/update/GeneralRegionAttributeSecurityService.java index cf1a03958892..3bbb53052a27 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/attribute/update/GeneralRegionAttributeSecurityService.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/attribute/update/GeneralRegionAttributeSecurityService.java @@ -31,6 +31,7 @@ import org.apache.iotdb.commons.exception.StartupException; import org.apache.iotdb.commons.service.IService; import org.apache.iotdb.commons.service.ServiceType; +import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.confignode.rpc.thrift.TShowClusterResp; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; @@ -93,9 +94,10 @@ public class GeneralRegionAttributeSecurityService implements IService { private volatile boolean allowSubmitListen = false; public void startBroadcast(final ISchemaRegion schemaRegion) { - if (schemaRegion instanceof SchemaRegionMemoryImpl) { + if (schemaRegion instanceof SchemaRegionMemoryImpl + && PathUtils.isTableModelDatabase(schemaRegion.getDatabaseFullPath())) { regionId2DatabaseMap.put( - schemaRegion.getSchemaRegionId(), schemaRegion.getDatabaseFullPath().substring(5)); + schemaRegion.getSchemaRegionId(), schemaRegion.getDatabaseFullPath()); regionLeaders.add(schemaRegion); } } From accfc34d7e80da48fdf0b184a7e785b31b220279 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 15:07:19 +0800 Subject: [PATCH 19/71] Fix --- .../plan/analyze/AnalyzeUtils.java | 47 +++++++------------ .../relational/planner/RelationPlanner.java | 5 +- .../TableDistributedPlanGenerator.java | 2 +- .../schema/CreateOrUpdateTableDeviceNode.java | 5 +- .../relational/sql/parser/AstBuilder.java | 26 ++++++---- 5 files changed, 37 insertions(+), 48 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java index a59c614902d3..4b00bc311987 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java @@ -74,8 +74,6 @@ import java.util.Set; import java.util.stream.Collectors; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_ROOT; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_SEPARATOR; import static org.apache.iotdb.db.queryengine.plan.execution.config.TableConfigTaskVisitor.DATABASE_NOT_SPECIFIED; public class AnalyzeUtils { @@ -115,7 +113,8 @@ public static InsertBaseStatement analyzeInsert( return realStatement; } - public static String getDatabaseName(InsertBaseStatement statement, MPPQueryContext context) { + public static String getDatabaseName( + final InsertBaseStatement statement, final MPPQueryContext context) { if (statement.getDatabaseName().isPresent()) { return statement.getDatabaseName().get(); } @@ -125,34 +124,22 @@ public static String getDatabaseName(InsertBaseStatement statement, MPPQueryCont return null; } - public static String getDatabaseNameForTableWithRoot( - InsertBaseStatement statement, MPPQueryContext context) { - if (statement.getDatabaseName().isPresent()) { - return PATH_ROOT + PATH_SEPARATOR + statement.getDatabaseName().get(); - } - if (context != null && context.getDatabaseName().isPresent()) { - return PATH_ROOT + PATH_SEPARATOR + context.getDatabaseName().get(); - } - return null; - } - public static List computeTableDataPartitionParams( - InsertBaseStatement statement, MPPQueryContext context) { + final InsertBaseStatement statement, final MPPQueryContext context) { if (statement instanceof InsertTabletStatement) { - InsertTabletStatement insertTabletStatement = (InsertTabletStatement) statement; - Map> timePartitionSlotMap = new HashMap<>(); + final InsertTabletStatement insertTabletStatement = (InsertTabletStatement) statement; + final Map> timePartitionSlotMap = new HashMap<>(); for (int i = 0; i < insertTabletStatement.getRowCount(); i++) { timePartitionSlotMap .computeIfAbsent(insertTabletStatement.getTableDeviceID(i), id -> new HashSet<>()) .add(insertTabletStatement.getTimePartitionSlot(i)); } - return computeDataPartitionParams( - timePartitionSlotMap, getDatabaseNameForTableWithRoot(statement, context)); + return computeDataPartitionParams(timePartitionSlotMap, getDatabaseName(statement, context)); } else if (statement instanceof InsertMultiTabletsStatement) { - InsertMultiTabletsStatement insertMultiTabletsStatement = + final InsertMultiTabletsStatement insertMultiTabletsStatement = (InsertMultiTabletsStatement) statement; - Map> timePartitionSlotMap = new HashMap<>(); - for (InsertTabletStatement insertTabletStatement : + final Map> timePartitionSlotMap = new HashMap<>(); + for (final InsertTabletStatement insertTabletStatement : insertMultiTabletsStatement.getInsertTabletStatementList()) { for (int i = 0; i < insertTabletStatement.getRowCount(); i++) { timePartitionSlotMap @@ -160,26 +147,24 @@ public static List computeTableDataPartitionParams( .add(insertTabletStatement.getTimePartitionSlot(i)); } } - return computeDataPartitionParams( - timePartitionSlotMap, getDatabaseNameForTableWithRoot(statement, context)); + return computeDataPartitionParams(timePartitionSlotMap, getDatabaseName(statement, context)); } else if (statement instanceof InsertRowStatement) { - InsertRowStatement insertRowStatement = (InsertRowStatement) statement; + final InsertRowStatement insertRowStatement = (InsertRowStatement) statement; return computeDataPartitionParams( Collections.singletonMap( insertRowStatement.getTableDeviceID(), Collections.singleton(insertRowStatement.getTimePartitionSlot())), - getDatabaseNameForTableWithRoot(statement, context)); + getDatabaseName(statement, context)); } else if (statement instanceof InsertRowsStatement) { - InsertRowsStatement insertRowsStatement = (InsertRowsStatement) statement; - Map> timePartitionSlotMap = new HashMap<>(); - for (InsertRowStatement insertRowStatement : + final InsertRowsStatement insertRowsStatement = (InsertRowsStatement) statement; + final Map> timePartitionSlotMap = new HashMap<>(); + for (final InsertRowStatement insertRowStatement : insertRowsStatement.getInsertRowStatementList()) { timePartitionSlotMap .computeIfAbsent(insertRowStatement.getTableDeviceID(), id -> new HashSet<>()) .add(insertRowStatement.getTimePartitionSlot()); } - return computeDataPartitionParams( - timePartitionSlotMap, getDatabaseNameForTableWithRoot(statement, context)); + return computeDataPartitionParams(timePartitionSlotMap, getDatabaseName(statement, context)); } throw new UnsupportedOperationException("computeDataPartitionParams for " + statement); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/RelationPlanner.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/RelationPlanner.java index 33bf0a6d5be7..4fda32333cde 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/RelationPlanner.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/RelationPlanner.java @@ -681,8 +681,9 @@ protected RelationPlan visitInsertRow(InsertRow node, Void context) { insertNode, analysis.getRootScope(), Collections.emptyList(), outerContext); } - protected RelationalInsertRowNode fromInsertRowStatement(InsertRowStatement insertRowStatement) { - RelationalInsertRowNode insertNode = + protected RelationalInsertRowNode fromInsertRowStatement( + final InsertRowStatement insertRowStatement) { + final RelationalInsertRowNode insertNode = new RelationalInsertRowNode( idAllocator.genPlanNodeId(), insertRowStatement.getDevicePath(), diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java index c392fb357a42..958e312c1310 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java @@ -970,7 +970,7 @@ private List visitAbstractTableDeviceQuery( @Override public List visitTableDeviceFetch( final TableDeviceFetchNode node, final PlanContext context) { - final String database = PathUtils.qualifyDatabaseName(node.getDatabase()); + final String database = node.getDatabase(); final Set schemaRegionSet = new HashSet<>(); final SchemaPartition schemaPartition = analysis.getSchemaPartitionInfo(); final Map databaseMap = diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/CreateOrUpdateTableDeviceNode.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/CreateOrUpdateTableDeviceNode.java index efc5c8f92784..316e483a34d1 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/CreateOrUpdateTableDeviceNode.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/CreateOrUpdateTableDeviceNode.java @@ -43,8 +43,6 @@ import java.util.Map; import java.util.Objects; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_ROOT; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_SEPARATOR; import static org.apache.iotdb.db.storageengine.dataregion.memtable.DeviceIDFactory.convertRawDeviceIDs2PartitionKeys; public class CreateOrUpdateTableDeviceNode extends WritePlanNode implements ISchemaRegionPlan { @@ -252,7 +250,6 @@ public static CreateOrUpdateTableDeviceNode deserialize(final ByteBuffer buffer) @Override public List splitByPartition(final IAnalysis analysis) { - final String dbNameForInvoke = PATH_ROOT + PATH_SEPARATOR + database; final Map> splitMap = new HashMap<>(); final List partitionKeyList = getPartitionKeyList(); for (int i = 0; i < partitionKeyList.size(); i++) { @@ -260,7 +257,7 @@ public List splitByPartition(final IAnalysis analysis) { final TRegionReplicaSet regionReplicaSet = analysis .getSchemaPartitionInfo() - .getSchemaRegionReplicaSet(dbNameForInvoke, partitionKeyList.get(i)); + .getSchemaRegionReplicaSet(database, partitionKeyList.get(i)); splitMap.computeIfAbsent(regionReplicaSet, k -> new ArrayList<>()).add(i); } final List result = new ArrayList<>(splitMap.size()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java index fcf65be1eb3a..8bc0f7524b83 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java @@ -467,8 +467,8 @@ public Node visitShowIndexStatement(RelationalSqlParser.ShowIndexStatementContex } @Override - public Node visitInsertStatement(RelationalSqlParser.InsertStatementContext ctx) { - QualifiedName qualifiedName = getQualifiedName(ctx.tableName); + public Node visitInsertStatement(final RelationalSqlParser.InsertStatementContext ctx) { + final QualifiedName qualifiedName = getQualifiedName(ctx.tableName); String tableName = qualifiedName.getSuffix(); String databaseName = qualifiedName @@ -481,9 +481,10 @@ public Node visitInsertStatement(RelationalSqlParser.InsertStatementContext ctx) tableName = tableName.toLowerCase(); databaseName = databaseName.toLowerCase(); - Query query = (Query) visit(ctx.query()); + final Query query = (Query) visit(ctx.query()); if (ctx.columnAliases() != null) { - List identifiers = visit(ctx.columnAliases().identifier(), Identifier.class); + final List identifiers = + visit(ctx.columnAliases().identifier(), Identifier.class); if (query.getQueryBody() instanceof Values) { return visitInsertValues( databaseName, tableName, identifiers, ((Values) query.getQueryBody())); @@ -492,7 +493,7 @@ public Node visitInsertStatement(RelationalSqlParser.InsertStatementContext ctx) } } else { if (query.getQueryBody() instanceof Values) { - TsTable table = DataNodeTableCache.getInstance().getTable(databaseName, tableName); + final TsTable table = DataNodeTableCache.getInstance().getTable(databaseName, tableName); if (table == null) { throw new SemanticException(new NoTableException(tableName)); } @@ -503,9 +504,10 @@ public Node visitInsertStatement(RelationalSqlParser.InsertStatementContext ctx) } } - private Node visitInsertValues(String databaseName, TsTable table, Values queryBody) { - List rows = queryBody.getRows(); - List rowStatements = + private Node visitInsertValues( + final String databaseName, final TsTable table, final Values queryBody) { + final List rows = queryBody.getRows(); + final List rowStatements = rows.stream() .map( r -> { @@ -528,8 +530,12 @@ private Node visitInsertValues(String databaseName, TsTable table, Values queryB } private Node visitInsertValues( - String databaseName, String tableName, List identifiers, Values queryBody) { - List columnNames = identifiers.stream().map(Identifier::getValue).collect(toList()); + final String databaseName, + final String tableName, + final List identifiers, + final Values queryBody) { + final List columnNames = + identifiers.stream().map(Identifier::getValue).collect(toList()); int timeColumnIndex = -1; for (int i = 0; i < columnNames.size(); i++) { if (TIME_COLUMN_NAME.equalsIgnoreCase(columnNames.get(i))) { From 56eff41a4fbb5fa7e722d079aa112c454e7a93d2 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 15:15:01 +0800 Subject: [PATCH 20/71] Fix --- .../db/queryengine/plan/analyze/ClusterPartitionFetcher.java | 4 +--- .../iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java | 2 +- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index 9a89c9f764d8..703f0dd1c56d 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -36,7 +36,6 @@ import org.apache.iotdb.commons.partition.executor.SeriesPartitionExecutor; import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.commons.path.PathPatternTree; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.confignode.rpc.thrift.TDataPartitionReq; import org.apache.iotdb.confignode.rpc.thrift.TDataPartitionTableResp; import org.apache.iotdb.confignode.rpc.thrift.TSchemaNodeManagementReq; @@ -471,8 +470,7 @@ private TDataPartitionReq constructDataPartitionReq( k, new TTimeSlotList( new ArrayList<>(v.timeSlotList), v.needLeftAll, v.needRightAll))); - partitionSlotsMap.put( - PathUtils.qualifyDatabaseName(entry.getKey()), deviceToTimePartitionMap); + partitionSlotsMap.put(entry.getKey(), deviceToTimePartitionMap); } return new TDataPartitionReq(partitionSlotsMap); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java index f90e349568db..c2859ac81349 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java @@ -75,7 +75,7 @@ DataPartition getOrCreateDataPartition( * @param userName */ DataPartition getOrCreateDataPartition( - List dataPartitionQueryParams, String userName); + final List dataPartitionQueryParams, final String userName); /** Get schema partition and matched nodes according to path pattern tree. */ default SchemaNodeManagementPartition getSchemaNodeManagementPartition( From f27dd8d742b630d68883d9cd6ba5d907a8837b03 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:24:33 +0800 Subject: [PATCH 21/71] Refactor --- .../confignode/manager/ConfigManager.java | 20 ++++++------ .../manager/load/cache/LoadCache.java | 2 +- .../manager/partition/PartitionManager.java | 8 ++--- .../manager/schema/ClusterSchemaManager.java | 12 +++---- .../persistence/partition/PartitionInfo.java | 2 +- .../persistence/schema/ClusterSchemaInfo.java | 21 +++++++----- .../thrift/ConfigNodeRPCServiceProcessor.java | 6 ++-- .../db/protocol/client/ConfigNodeClient.java | 4 +-- .../plan/analyze/ClusterPartitionFetcher.java | 4 +-- .../cache/partition/PartitionCache.java | 32 ++++++++++--------- .../plan/execution/QueryExecution.java | 4 +-- .../metadata/TableMetadataImpl.java | 3 +- .../TableDistributedPlanGenerator.java | 4 +-- .../PushPredicateIntoTableScan.java | 25 ++++++++------- .../impl/SchemaRegionMemoryImpl.java | 2 +- .../impl/mem/MTreeBelowSGMemoryImpl.java | 2 +- .../commons/partition/DataPartition.java | 12 +++---- .../iotdb/commons/path/PartialPath.java | 9 ++++-- .../apache/iotdb/commons/utils/PathUtils.java | 4 +-- 19 files changed, 93 insertions(+), 83 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index f85caf36ae1e..04c4385841fc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -800,7 +800,7 @@ public TSchemaPartitionTableResp getSchemaPartition( final List allDatabasePaths = new ArrayList<>(); for (final String database : allDatabases) { try { - allDatabasePaths.add(PartialPath.getDatabasePath(database)); + allDatabasePaths.add(PartialPath.getQualifiedDatabasePartialPath(database)); } catch (final IllegalPathException e) { throw new RuntimeException(e); } @@ -852,20 +852,20 @@ public TSchemaPartitionTableResp getSchemaPartition( @Override public TSchemaPartitionTableResp getOrCreateSchemaPartition( final PathPatternTree patternTree, final boolean isTableModel) { - TSStatus status = confirmLeader(); + final TSStatus status = confirmLeader(); if (status.getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // Construct empty response - TSchemaPartitionTableResp resp = new TSchemaPartitionTableResp(); + final TSchemaPartitionTableResp resp = new TSchemaPartitionTableResp(); return resp.setStatus(status); } - List devicePaths = patternTree.getAllDevicePatterns(); - List databases = getClusterSchemaManager().getDatabaseNames(isTableModel); + final List devicePaths = patternTree.getAllDevicePatterns(); + final List databases = getClusterSchemaManager().getDatabaseNames(isTableModel); // Build GetOrCreateSchemaPartitionPlan - Map> partitionSlotsMap = new HashMap<>(); - for (IDeviceID deviceID : devicePaths) { - for (String database : databases) { + final Map> partitionSlotsMap = new HashMap<>(); + for (final IDeviceID deviceID : devicePaths) { + for (final String database : databases) { if (PathUtils.isStartWith(deviceID, database)) { partitionSlotsMap .computeIfAbsent(database, key -> new HashSet<>()) @@ -875,14 +875,14 @@ public TSchemaPartitionTableResp getOrCreateSchemaPartition( } } - Map> partitionSlotListMap = new HashMap<>(); + final Map> partitionSlotListMap = new HashMap<>(); partitionSlotsMap.forEach((db, slots) -> partitionSlotListMap.put(db, new ArrayList<>(slots))); return getOrCreateSchemaPartition(partitionSlotListMap); } @Override public TSchemaPartitionTableResp getOrCreateSchemaPartition( - Map> dbSlotMap) { + final Map> dbSlotMap) { TSStatus status = confirmLeader(); if (status.getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/cache/LoadCache.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/cache/LoadCache.java index dfa93aea1019..cab1153a7e40 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/cache/LoadCache.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/cache/LoadCache.java @@ -96,7 +96,7 @@ public LoadCache() { this.confirmedConfigNodeMap = new ConcurrentHashMap<>(); } - public void initHeartbeatCache(IManager configManager) { + public void initHeartbeatCache(final IManager configManager) { initNodeHeartbeatCache( configManager.getNodeManager().getRegisteredConfigNodes(), configManager.getNodeManager().getRegisteredDataNodes(), diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index 6bc470cff260..8a5bf0269383 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -841,7 +841,7 @@ public List getAllRegionGroupIds(String database, TConsensusG * @param database The specified Database * @return True if the DatabaseSchema is exists and the Database is not pre-deleted */ - public boolean isDatabaseExist(String database) { + public boolean isDatabaseExist(final String database) { return partitionInfo.isDatabaseExisted(database); } @@ -851,12 +851,12 @@ public boolean isDatabaseExist(String database) { * @param databases the Databases to check * @return List of PartialPath the Databases that not exist */ - public List filterUnExistDatabases(List databases) { - List unExistDatabases = new ArrayList<>(); + public List filterUnExistDatabases(final List databases) { + final List unExistDatabases = new ArrayList<>(); if (databases == null) { return unExistDatabases; } - for (PartialPath database : databases) { + for (final PartialPath database : databases) { if (!isDatabaseExist(database.getFullPath())) { unExistDatabases.add(database); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index ab77de28b618..83a067ff566d 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -396,17 +396,17 @@ public TShowDatabaseResp showDatabase(final GetDatabasePlan getDatabasePlan) { } public Map getTTLInfoForUpgrading() { - List databases = getDatabaseNames(null); - Map infoMap = new ConcurrentHashMap<>(); - for (String database : databases) { + final List databases = getDatabaseNames(false); + final Map infoMap = new ConcurrentHashMap<>(); + for (final String database : databases) { try { final TDatabaseSchema databaseSchema = getDatabaseSchemaByName(database); - long ttl = databaseSchema.isSetTTL() ? databaseSchema.getTTL() : -1; + final long ttl = databaseSchema.isSetTTL() ? databaseSchema.getTTL() : -1; if (ttl < 0 || ttl == Long.MAX_VALUE) { continue; } infoMap.put(database, ttl); - } catch (DatabaseNotExistsException e) { + } catch (final DatabaseNotExistsException e) { LOGGER.warn("Database: {} doesn't exist", databases, e); } } @@ -579,7 +579,7 @@ public static int calcMaxRegionGroupNum( * @param database The specified Database * @return True if the DatabaseSchema exists and the Database is not pre-deleted */ - public boolean isDatabaseExist(String database) { + public boolean isDatabaseExist(final String database) { return getPartitionManager().isDatabaseExist(database); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index b17cd73fc0c1..c96d4a95eeeb 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -460,7 +460,7 @@ public TConsensusGroupId getPredecessorDataPartition( * @param database The specified Database * @return True if the DatabaseSchema is exists and the Database is not pre-deleted */ - public boolean isDatabaseExisted(String database) { + public boolean isDatabaseExisted(final String database) { final DatabasePartitionTable databasePartitionTable = databasePartitionTables.get(database); return databasePartitionTable != null && databasePartitionTable.isNotPreDeleted(); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 86d7aedf624b..e03bc96da3c6 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -111,6 +111,7 @@ import static org.apache.iotdb.commons.conf.IoTDBConstant.ONE_LEVEL_PATH_WILDCARD; import static org.apache.iotdb.commons.conf.IoTDBConstant.TTL_INFINITE; +import static org.apache.iotdb.commons.path.PartialPath.getQualifiedDatabasePartialPath; import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_MATCH_PATTERN; import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_MATCH_SCOPE; import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_TEMPLATE; @@ -483,9 +484,18 @@ public TSStatus adjustMaxRegionGroupCount(final AdjustMaxRegionGroupNumPlan plan public List getDatabaseNames(final Boolean isTableModel) { databaseReadWriteLock.readLock().lock(); try { - return treeModelMTree.getAllDatabasePaths(isTableModel).stream() - .map(PartialPath::getFullPath) - .collect(Collectors.toList()); + final List results = new ArrayList<>(); + if (!Boolean.TRUE.equals(isTableModel)) { + treeModelMTree.getAllDatabasePaths(isTableModel).stream() + .map(PartialPath::getFullPath) + .forEach(results::add); + } + if (!Boolean.FALSE.equals(isTableModel)) { + tableModelMTree.getAllDatabasePaths(isTableModel).stream() + .map(path -> path.getNodes()[1]) + .forEach(results::add); + } + return results; } finally { databaseReadWriteLock.readLock().unlock(); } @@ -1342,11 +1352,6 @@ public TSStatus commitDeleteColumn(final CommitDeleteColumnPlan plan) { } } - private PartialPath getQualifiedDatabasePartialPath(final String database) - throws IllegalPathException { - return PartialPath.getDatabasePath(PathUtils.qualifyDatabaseName(database)); - } - // endregion @TestOnly diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 0e0dc775ff89..b9b62cc62804 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -629,13 +629,13 @@ public TSchemaPartitionTableResp getSchemaPartitionTable(final TSchemaPartitionR @Override public TSchemaPartitionTableResp getSchemaPartitionTableWithSlots( - Map> dbSlotMap) { + final Map> dbSlotMap) { return configManager.getSchemaPartition(dbSlotMap); } @Override - public TSchemaPartitionTableResp getOrCreateSchemaPartitionTable(TSchemaPartitionReq req) { - PathPatternTree patternTree = + public TSchemaPartitionTableResp getOrCreateSchemaPartitionTable(final TSchemaPartitionReq req) { + final PathPatternTree patternTree = PathPatternTree.deserialize(ByteBuffer.wrap(req.getPathPatternTree())); return configManager.getOrCreateSchemaPartition( patternTree, req.isSetIsTableModel() && req.isIsTableModel()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/client/ConfigNodeClient.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/client/ConfigNodeClient.java index e9bfb6ce6472..a3ff327e9ef5 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/client/ConfigNodeClient.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/client/ConfigNodeClient.java @@ -604,7 +604,7 @@ public TSStatus setTimePartitionInterval(TSetTimePartitionIntervalReq req) throw } @Override - public TSchemaPartitionTableResp getSchemaPartitionTable(TSchemaPartitionReq req) + public TSchemaPartitionTableResp getSchemaPartitionTable(final TSchemaPartitionReq req) throws TException { return executeRemoteCallWithRetry( () -> client.getSchemaPartitionTable(req), resp -> !updateConfigNodeLeader(resp.status)); @@ -612,7 +612,7 @@ public TSchemaPartitionTableResp getSchemaPartitionTable(TSchemaPartitionReq req @Override public TSchemaPartitionTableResp getSchemaPartitionTableWithSlots( - Map> dbSlotMap) throws TException { + final Map> dbSlotMap) throws TException { return executeRemoteCallWithRetry( () -> client.getSchemaPartitionTableWithSlots(dbSlotMap), resp -> !updateConfigNodeLeader(resp.status)); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index 703f0dd1c56d..c92998a3d2cb 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -405,7 +405,7 @@ private TSchemaPartitionReq constructSchemaPartitionReq( final PathPatternTree patternTree, final boolean isTableModel) { try { return new TSchemaPartitionReq(patternTree.serialize()).setIsTableModel(isTableModel); - } catch (IOException e) { + } catch (final IOException e) { throw new StatementAnalyzeException("An error occurred when serializing pattern tree"); } } @@ -422,7 +422,7 @@ private TSchemaNodeManagementReq constructSchemaNodeManagementPartitionReq( schemaNodeManagementReq.setLevel(level); } return schemaNodeManagementReq; - } catch (IOException e) { + } catch (final IOException e) { throw new StatementAnalyzeException("An error occurred when serializing pattern tree"); } } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java index f84d0477d107..2ca3c4ce749f 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/cache/partition/PartitionCache.java @@ -614,21 +614,23 @@ public void invalidReplicaSetCache() { * @param databaseToDeviceMap database to devices map * @return SchemaPartition of databaseToDeviceMap */ - public SchemaPartition getSchemaPartition(Map> databaseToDeviceMap) { + public SchemaPartition getSchemaPartition( + final Map> databaseToDeviceMap) { schemaPartitionCacheLock.readLock().lock(); try { if (databaseToDeviceMap.isEmpty()) { cacheMetrics.record(false, CacheMetrics.SCHEMA_PARTITION_CACHE_NAME); return null; } - Map> schemaPartitionMap = + final Map> schemaPartitionMap = new HashMap<>(); // check cache for each database - for (Map.Entry> entry : databaseToDeviceMap.entrySet()) { - String databaseName = entry.getKey(); - Map regionReplicaSetMap = + for (final Map.Entry> entry : databaseToDeviceMap.entrySet()) { + final String databaseName = entry.getKey(); + final Map regionReplicaSetMap = schemaPartitionMap.computeIfAbsent(databaseName, k -> new HashMap<>()); - SchemaPartitionTable schemaPartitionTable = schemaPartitionCache.getIfPresent(databaseName); + final SchemaPartitionTable schemaPartitionTable = + schemaPartitionCache.getIfPresent(databaseName); if (null == schemaPartitionTable) { // if database not find, then return cache miss. logger.debug( @@ -638,11 +640,11 @@ public SchemaPartition getSchemaPartition(Map> databaseT cacheMetrics.record(false, CacheMetrics.SCHEMA_PARTITION_CACHE_NAME); return null; } - Map map = + final Map map = schemaPartitionTable.getSchemaPartitionMap(); // check cache for each device - for (IDeviceID device : entry.getValue()) { - TSeriesPartitionSlot seriesPartitionSlot = + for (final IDeviceID device : entry.getValue()) { + final TSeriesPartitionSlot seriesPartitionSlot = partitionExecutor.getSeriesPartitionSlot(device); if (!map.containsKey(seriesPartitionSlot)) { // if one device not find, then return cache miss. @@ -653,8 +655,8 @@ public SchemaPartition getSchemaPartition(Map> databaseT cacheMetrics.record(false, CacheMetrics.SCHEMA_PARTITION_CACHE_NAME); return null; } - TConsensusGroupId consensusGroupId = map.get(seriesPartitionSlot); - TRegionReplicaSet regionReplicaSet = getRegionReplicaSet(consensusGroupId); + final TConsensusGroupId consensusGroupId = map.get(seriesPartitionSlot); + final TRegionReplicaSet regionReplicaSet = getRegionReplicaSet(consensusGroupId); regionReplicaSetMap.put(seriesPartitionSlot, regionReplicaSet); } } @@ -711,18 +713,18 @@ public SchemaPartition getSchemaPartition(String database) { * @param schemaPartitionTable database to SeriesPartitionSlot to ConsensusGroupId map */ public void updateSchemaPartitionCache( - Map> schemaPartitionTable) { + final Map> schemaPartitionTable) { schemaPartitionCacheLock.writeLock().lock(); try { - for (Map.Entry> entry1 : + for (final Map.Entry> entry1 : schemaPartitionTable.entrySet()) { - String databaseName = entry1.getKey(); + final String databaseName = entry1.getKey(); SchemaPartitionTable result = schemaPartitionCache.getIfPresent(databaseName); if (null == result) { result = new SchemaPartitionTable(); schemaPartitionCache.put(databaseName, result); } - Map seriesPartitionSlotTConsensusGroupIdMap = + final Map seriesPartitionSlotTConsensusGroupIdMap = result.getSchemaPartitionMap(); seriesPartitionSlotTConsensusGroupIdMap.putAll(entry1.getValue()); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/QueryExecution.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/QueryExecution.java index 87a02f161316..0e2bda84205a 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/QueryExecution.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/QueryExecution.java @@ -289,11 +289,11 @@ public void doLogicalPlan() { // Generate the distributed plan and split it into fragments public void doDistributedPlan() { - long startTime = System.nanoTime(); + final long startTime = System.nanoTime(); this.distributedPlan = planner.doDistributionPlan(analysis, logicalPlan); if (analysis.isQuery()) { - long distributionPlanCost = System.nanoTime() - startTime; + final long distributionPlanCost = System.nanoTime() - startTime; context.setDistributionPlanCost(distributionPlanCost); QUERY_PLAN_COST_METRIC_SET.recordPlanCost( TREE_TYPE, DISTRIBUTION_PLANNER, distributionPlanCost); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java index be86c26cbba6..ceab9ec3da64 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java @@ -28,6 +28,7 @@ import org.apache.iotdb.commons.udf.builtin.relational.TableBuiltinScalarFunction; import org.apache.iotdb.commons.udf.utils.TableUDFUtils; import org.apache.iotdb.commons.udf.utils.UDFDataTypeTransformer; +import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.queryengine.common.MPPQueryContext; import org.apache.iotdb.db.queryengine.common.SessionInfo; @@ -734,7 +735,7 @@ public SchemaPartition getSchemaPartition( @Override public SchemaPartition getSchemaPartition(final String database) { - return partitionFetcher.getSchemaPartition(database); + return partitionFetcher.getSchemaPartition(PathUtils.qualifyDatabaseName(database)); } @Override diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java index 958e312c1310..8e3cc11f166c 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java @@ -24,7 +24,6 @@ import org.apache.iotdb.common.rpc.thrift.TSeriesPartitionSlot; import org.apache.iotdb.commons.partition.SchemaPartition; import org.apache.iotdb.commons.schema.table.column.TsTableColumnCategory; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.queryengine.common.MPPQueryContext; import org.apache.iotdb.db.queryengine.common.QueryId; import org.apache.iotdb.db.queryengine.plan.planner.distribution.NodeDistribution; @@ -941,12 +940,11 @@ public List visitTableDeviceQueryCount( private List visitAbstractTableDeviceQuery( final AbstractTableDeviceQueryNode node, final PlanContext context) { - final String database = PathUtils.qualifyDatabaseName(node.getDatabase()); final Set schemaRegionSet = new HashSet<>(); analysis .getSchemaPartitionInfo() .getSchemaPartitionMap() - .get(database) + .get(node.getDatabase()) .forEach( (deviceGroupId, schemaRegionReplicaSet) -> schemaRegionSet.add(schemaRegionReplicaSet)); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java index feeda5047eb0..ada319190860 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java @@ -416,15 +416,16 @@ private SplitExpression splitPredicate(DeviceTableScanNode node, Expression pred } private void getDeviceEntriesWithDataPartitions( - DeviceTableScanNode tableScanNode, - List metadataExpressions, + final DeviceTableScanNode tableScanNode, + final List metadataExpressions, String timeColumnName) { - List attributeColumns = new ArrayList<>(); + final List attributeColumns = new ArrayList<>(); int attributeIndex = 0; - for (Map.Entry entry : tableScanNode.getAssignments().entrySet()) { - Symbol columnSymbol = entry.getKey(); - ColumnSchema columnSchema = entry.getValue(); + for (final Map.Entry entry : + tableScanNode.getAssignments().entrySet()) { + final Symbol columnSymbol = entry.getKey(); + final ColumnSchema columnSchema = entry.getValue(); if (ATTRIBUTE.equals(columnSchema.getColumnCategory())) { attributeColumns.add(columnSchema.getName()); tableScanNode.getIdAndAttributeIndexMap().put(columnSymbol, attributeIndex++); @@ -432,7 +433,7 @@ private void getDeviceEntriesWithDataPartitions( } long startTime = System.nanoTime(); - List deviceEntries = + final List deviceEntries = metadata.indexScan( tableScanNode.getQualifiedObjectName(), metadataExpressions.stream() @@ -445,7 +446,7 @@ private void getDeviceEntriesWithDataPartitions( queryContext); tableScanNode.setDeviceEntries(deviceEntries); - long schemaFetchCost = System.nanoTime() - startTime; + final long schemaFetchCost = System.nanoTime() - startTime; QueryPlanCostMetricSet.getInstance() .recordPlanCost(TABLE_TYPE, SCHEMA_FETCHER, schemaFetchCost); queryContext.setFetchSchemaCost(schemaFetchCost); @@ -457,18 +458,18 @@ private void getDeviceEntriesWithDataPartitions( analysis.setFinishQueryAfterAnalyze(); } } else { - Filter timeFilter = + final Filter timeFilter = tableScanNode .getTimePredicate() .map(value -> value.accept(new ConvertPredicateToTimeFilterVisitor(), null)) .orElse(null); tableScanNode.setTimeFilter(timeFilter); - String treeModelDatabase = + final String treeModelDatabase = "root." + tableScanNode.getQualifiedObjectName().getDatabaseName(); startTime = System.nanoTime(); - DataPartition dataPartition = + final DataPartition dataPartition = fetchDataPartitionByDevices(treeModelDatabase, deviceEntries, timeFilter); if (dataPartition.getDataPartitionMap().size() > 1) { @@ -486,7 +487,7 @@ private void getDeviceEntriesWithDataPartitions( analysis.upsertDataPartition(dataPartition); } - long fetchPartitionCost = System.nanoTime() - startTime; + final long fetchPartitionCost = System.nanoTime() - startTime; QueryPlanCostMetricSet.getInstance() .recordPlanCost(TABLE_TYPE, PARTITION_FETCHER, fetchPartitionCost); queryContext.setFetchPartitionCost(fetchPartitionCost); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java index 589642fd89fc..f86bf5f56075 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java @@ -268,7 +268,7 @@ public synchronized void init() throws MetadataException { tagManager = new TagManager(schemaRegionDirPath, regionStatistics); mtree = new MTreeBelowSGMemoryImpl( - PartialPath.getDatabasePath(storageGroupFullPath), + PartialPath.getQualifiedDatabasePartialPath(storageGroupFullPath), tagManager::readTags, tagManager::readAttributes, regionStatistics, diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/mtree/impl/mem/MTreeBelowSGMemoryImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/mtree/impl/mem/MTreeBelowSGMemoryImpl.java index d9a09bed98d9..3611ebd29113 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/mtree/impl/mem/MTreeBelowSGMemoryImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/mtree/impl/mem/MTreeBelowSGMemoryImpl.java @@ -200,7 +200,7 @@ public static MTreeBelowSGMemoryImpl loadFromSnapshot( final Function, Map> attributeGetter) throws IOException, IllegalPathException { return new MTreeBelowSGMemoryImpl( - PartialPath.getDatabasePath(storageGroupFullPath), + PartialPath.getQualifiedDatabasePartialPath(storageGroupFullPath), MemMTreeStore.loadFromSnapshot( snapshotDir, measurementProcess, diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java index 1420b71b7f73..09ee7616ec67 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java @@ -234,17 +234,15 @@ public List getDataRegionReplicaSetForWriting( } public TRegionReplicaSet getDataRegionReplicaSetForWriting( - IDeviceID deviceID, TTimePartitionSlot timePartitionSlot, String databaseName) { + final IDeviceID deviceID, final TTimePartitionSlot timePartitionSlot, String databaseName) { // A list of data region replica sets will store data in a same time partition. // We will insert data to the last set in the list. // TODO return the latest dataRegionReplicaSet for each time partition - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); - if (databaseName != null) { - databaseName = PathUtils.qualifyDatabaseName(databaseName); - } else { + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); + if (databaseName == null) { databaseName = getDatabaseNameByDevice(deviceID); } - Map>> + final Map>> databasePartitionMap = dataPartitionMap.get(databaseName); if (databasePartitionMap == null) { throw new RuntimeException( @@ -252,7 +250,7 @@ public TRegionReplicaSet getDataRegionReplicaSetForWriting( + databaseName + " not exists and failed to create automatically because enable_auto_create_schema is FALSE."); } - List regions = + final List regions = databasePartitionMap.get(seriesPartitionSlot).get(timePartitionSlot); // IMPORTANT TODO: (xingtanzjr) need to handle the situation for write operation that there // are more than 1 Regions for one timeSlot diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java index 0a62938ff903..c61d3101506b 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java @@ -120,10 +120,15 @@ protected PartialPath(String device, String measurement) throws IllegalPathExcep /** * @param partialNodes nodes of a time series path */ - public PartialPath(String[] partialNodes) { + public PartialPath(final String[] partialNodes) { nodes = partialNodes; } + public static PartialPath getQualifiedDatabasePartialPath(final String database) + throws IllegalPathException { + return PartialPath.getDatabasePath(PathUtils.qualifyDatabaseName(database)); + } + /** * Get the database {@link PartialPath}. The tree model grammar shall call the {@link * #PartialPath(String)} first to trim the "`"s if it has only one "." after {@link @@ -149,7 +154,7 @@ public static PartialPath getDatabasePath(final String path) throws IllegalPathE * @param path path * @param needSplit whether to split path to nodes, needSplit can only be false. */ - public PartialPath(String path, boolean needSplit) { + public PartialPath(final String path, final boolean needSplit) { Validate.isTrue(!needSplit); fullPath = path; if ("".equals(path)) { diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java index 26ea7fb62c77..2b3a7c3227c7 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java @@ -178,11 +178,11 @@ public static String checkAndReturnSingleMeasurement(String measurement) } /** Return true if the str is a real number. Examples: 1.0; +1.0; -1.0; 0011; 011e3; +23e-3 */ - public static boolean isRealNumber(String str) { + public static boolean isRealNumber(final String str) { return PathVisitor.isRealNumber(str); } - public static boolean isStartWith(IDeviceID deviceID, String storageGroup) { + public static boolean isStartWith(final IDeviceID deviceID, final String storageGroup) { return deviceID.segmentNum() > 0 && deviceID.matchDatabaseName(storageGroup); } From 89a54095ea38f728ee60152fbe2d3a1373575aa9 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:32:59 +0800 Subject: [PATCH 22/71] Update PushPredicateIntoTableScan.java --- .../planner/optimizations/PushPredicateIntoTableScan.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java index ada319190860..72f3ade0c69e 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java @@ -465,12 +465,13 @@ private void getDeviceEntriesWithDataPartitions( .orElse(null); tableScanNode.setTimeFilter(timeFilter); - final String treeModelDatabase = - "root." + tableScanNode.getQualifiedObjectName().getDatabaseName(); startTime = System.nanoTime(); final DataPartition dataPartition = - fetchDataPartitionByDevices(treeModelDatabase, deviceEntries, timeFilter); + fetchDataPartitionByDevices( + tableScanNode.getQualifiedObjectName().getDatabaseName(), + deviceEntries, + timeFilter); if (dataPartition.getDataPartitionMap().size() > 1) { throw new IllegalStateException( From 33c38c4e9accdee50b02e7397e07b82fce22b80f Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:44:29 +0800 Subject: [PATCH 23/71] fix --- .../plan/analyze/AnalyzeUtils.java | 20 +++++++++---------- .../commons/partition/DataPartition.java | 6 ++---- 2 files changed, 12 insertions(+), 14 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java index 4b00bc311987..52bfcf2222b1 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java @@ -290,12 +290,12 @@ public static InsertBaseStatement removeLogicalView( /** get analysis according to statement and params */ public static void analyzeDataPartition( - IAnalysis analysis, - List dataPartitionQueryParams, - String userName, - DataPartitionQueryFunc partitionQueryFunc) { + final IAnalysis analysis, + final List dataPartitionQueryParams, + final String userName, + final DataPartitionQueryFunc partitionQueryFunc) { - DataPartition dataPartition = + final DataPartition dataPartition = partitionQueryFunc.queryDataPartition(dataPartitionQueryParams, userName); if (dataPartition.isEmpty()) { analysis.setFinishQueryAfterAnalyze(true); @@ -308,20 +308,20 @@ public static void analyzeDataPartition( analysis.setDataPartitionInfo(dataPartition); } - public static void analyzeDelete(Delete node, MPPQueryContext queryContext) { + public static void analyzeDelete(final Delete node, final MPPQueryContext queryContext) { queryContext.setQueryType(QueryType.WRITE); validateSchema(node, queryContext); - try (ConfigNodeClient configNodeClient = + try (final ConfigNodeClient configNodeClient = ConfigNodeClientManager.getInstance().borrowClient(ConfigNodeInfo.CONFIG_REGION_ID); ) { // TODO: may use time and db/table to filter - TRegionRouteMapResp latestRegionRouteMap = configNodeClient.getLatestRegionRouteMap(); - Set replicaSets = new HashSet<>(); + final TRegionRouteMapResp latestRegionRouteMap = configNodeClient.getLatestRegionRouteMap(); + final Set replicaSets = new HashSet<>(); latestRegionRouteMap.getRegionRouteMap().entrySet().stream() .filter(e -> e.getKey().getType() == TConsensusGroupType.DataRegion) .forEach(e -> replicaSets.add(e.getValue())); node.setReplicaSets(replicaSets); - } catch (Exception e) { + } catch (final Exception e) { throw new IoTDBRuntimeException(e, TSStatusCode.CAN_NOT_CONNECT_CONFIGNODE.getStatusCode()); } } diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java index 09ee7616ec67..9c0789b15097 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java @@ -163,10 +163,8 @@ public List getDataRegionReplicaSetWithTimeFilter( *

The device id shall be [table, seg1, ....] */ public List getDataRegionReplicaSetWithTimeFilter( - String database, IDeviceID deviceId, Filter timeFilter) { - // TODO perfect this interface, @Potato - database = PathUtils.qualifyDatabaseName(database); - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceId); + final String database, final IDeviceID deviceId, final Filter timeFilter) { + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceId); if (!dataPartitionMap.containsKey(database) || !dataPartitionMap.get(database).containsKey(seriesPartitionSlot)) { return Collections.singletonList(NOT_ASSIGNED); From c116ec7d45e4f1664163a25fe51771ee7f1d1569 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:49:32 +0800 Subject: [PATCH 24/71] Update DataPartition.java --- .../commons/partition/DataPartition.java | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java index 9c0789b15097..a8470c7005d5 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java @@ -139,9 +139,9 @@ public List> getTimePartitionRange( } public List getDataRegionReplicaSetWithTimeFilter( - IDeviceID deviceId, Filter timeFilter) { - String storageGroup = getDatabaseNameByDevice(deviceId); - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceId); + final IDeviceID deviceId, final Filter timeFilter) { + final String storageGroup = getDatabaseNameByDevice(deviceId); + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceId); if (!dataPartitionMap.containsKey(storageGroup) || !dataPartitionMap.get(storageGroup).containsKey(seriesPartitionSlot)) { return Collections.singletonList(NOT_ASSIGNED); @@ -179,20 +179,21 @@ public List getDataRegionReplicaSetWithTimeFilter( } public List getDataRegionReplicaSet( - IDeviceID deviceID, TTimePartitionSlot tTimePartitionSlot) { - String storageGroup = getDatabaseNameByDevice(deviceID); - Map>> dbMap = + final IDeviceID deviceID, final TTimePartitionSlot tTimePartitionSlot) { + final String storageGroup = getDatabaseNameByDevice(deviceID); + final Map>> dbMap = dataPartitionMap.get(storageGroup); if (dbMap == null) { return Collections.singletonList(NOT_ASSIGNED); } - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); - Map> seriesSlotMap = dbMap.get(seriesPartitionSlot); + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); + final Map> seriesSlotMap = + dbMap.get(seriesPartitionSlot); if (seriesSlotMap == null) { return Collections.singletonList(NOT_ASSIGNED); } - List regionReplicaSets = seriesSlotMap.get(tTimePartitionSlot); + final List regionReplicaSets = seriesSlotMap.get(tTimePartitionSlot); if (regionReplicaSets == null) { return Collections.singletonList(NOT_ASSIGNED); From a41eaf789cdffc924e70f290830051ef006e8df8 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:54:55 +0800 Subject: [PATCH 25/71] Fix --- .../iotdb/confignode/persistence/schema/ClusterSchemaInfo.java | 2 +- .../execution/config/executor/ClusterConfigTaskExecutor.java | 3 +-- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index e03bc96da3c6..1b8928201f4e 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -618,7 +618,7 @@ public int getMinRegionGroupNum( try { final TDatabaseSchema storageGroupSchema = (PathUtils.isTableModelDatabase(database) ? tableModelMTree : treeModelMTree) - .getDatabaseNodeByDatabasePath(PartialPath.getDatabasePath(database)) + .getDatabaseNodeByDatabasePath(getQualifiedDatabasePartialPath(database)) .getAsMNode() .getDatabaseSchema(); switch (consensusGroupType) { diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 7a05409ac8cd..1860102ff2aa 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -3155,8 +3155,7 @@ public SettableFuture createDatabase( } else { future.setException( new IoTDBException( - String.format( - "Database %s already exists", databaseSchema.getName().substring(5)), + String.format("Database %s already exists", databaseSchema.getName()), TSStatusCode.DATABASE_ALREADY_EXISTS.getStatusCode())); } } else { From e4a7de5502b96cb803b1ce6258db52e5191a4ea3 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 16:58:48 +0800 Subject: [PATCH 26/71] Fix --- .../manager/schema/ClusterSchemaManager.java | 19 ++++++++++--------- .../persistence/schema/ClusterSchemaInfo.java | 6 ++++-- 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 83a067ff566d..9d68f2e27ce2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -155,17 +155,18 @@ public TSStatus setDatabase( final DatabaseSchemaPlan databaseSchemaPlan, final boolean isGeneratedByPipe) { TSStatus result; - if (getPartitionManager().isDatabasePreDeleted(databaseSchemaPlan.getSchema().getName())) { + final TDatabaseSchema schema = databaseSchemaPlan.getSchema(); + if (getPartitionManager().isDatabasePreDeleted(schema.getName())) { return RpcUtils.getStatus( TSStatusCode.METADATA_ERROR, - String.format( - "Some other task is deleting database %s", databaseSchemaPlan.getSchema().getName())); + String.format("Some other task is deleting database %s", schema.getName())); } createDatabaseLock.lock(); try { - clusterSchemaInfo.isDatabaseNameValid(databaseSchemaPlan.getSchema().getName()); - if (!databaseSchemaPlan.getSchema().getName().equals(SchemaConstant.SYSTEM_DATABASE)) { + clusterSchemaInfo.isDatabaseNameValid( + schema.getName(), schema.isSetIsTableModel() && schema.isIsTableModel()); + if (!schema.getName().equals(SchemaConstant.SYSTEM_DATABASE)) { clusterSchemaInfo.checkDatabaseLimit(); } // Cache DatabaseSchema @@ -176,16 +177,16 @@ public TSStatus setDatabase( ? new PipeEnrichedPlan(databaseSchemaPlan) : databaseSchemaPlan); // set ttl - if (databaseSchemaPlan.getSchema().isSetTTL()) { + if (schema.isSetTTL()) { result = configManager.getTTLManager().setTTL(databaseSchemaPlan, isGeneratedByPipe); } // Bind Database metrics PartitionMetrics.bindDatabaseRelatedMetricsWhenUpdate( MetricService.getInstance(), configManager, - databaseSchemaPlan.getSchema().getName(), - databaseSchemaPlan.getSchema().getDataReplicationFactor(), - databaseSchemaPlan.getSchema().getSchemaReplicationFactor()); + schema.getName(), + schema.getDataReplicationFactor(), + schema.getSchemaReplicationFactor()); // Adjust the maximum RegionGroup number of each Database adjustMaxRegionGroupNum(); } catch (final ConsensusException e) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 1b8928201f4e..9f5ade04063f 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -508,10 +508,12 @@ public List getDatabaseNames(final Boolean isTableModel) { * @throws MetadataException If the DatabaseName invalid i.e. the specified DatabaseName is * already exist, or it's a prefix of another DatabaseName */ - public void isDatabaseNameValid(final String databaseName) throws MetadataException { + public void isDatabaseNameValid(final String databaseName, final boolean isTableModel) + throws MetadataException { databaseReadWriteLock.readLock().lock(); try { - treeModelMTree.checkDatabaseAlreadySet(getQualifiedDatabasePartialPath(databaseName)); + (isTableModel ? tableModelMTree : treeModelMTree) + .checkDatabaseAlreadySet(getQualifiedDatabasePartialPath(databaseName)); } finally { databaseReadWriteLock.readLock().unlock(); } From 22eeafc7768eabc68fb2c7782bdbb3237c29188c Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 17:08:12 +0800 Subject: [PATCH 27/71] Update SchemaPartition.java --- .../iotdb/commons/partition/SchemaPartition.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/SchemaPartition.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/SchemaPartition.java index 609456b8ae05..3fc99857396b 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/SchemaPartition.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/SchemaPartition.java @@ -81,12 +81,12 @@ public TRegionReplicaSet getSchemaRegionReplicaSet(String database, IDeviceID de } // [root, db, ....] - public TRegionReplicaSet getSchemaRegionReplicaSet(IDeviceID deviceID) { + public TRegionReplicaSet getSchemaRegionReplicaSet(final IDeviceID deviceID) { // A list of data region replica sets will store data in a same time partition. // We will insert data to the last set in the list. // TODO return the latest dataRegionReplicaSet for each time partition - String storageGroup = getStorageGroupByDevice(deviceID); - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); + final String storageGroup = getStorageGroupByDevice(deviceID); + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); if (schemaPartitionMap.get(storageGroup) == null) { throw new RuntimeException( new IoTDBException("Path does not exist. ", TSStatusCode.PATH_NOT_EXIST.getStatusCode())); @@ -94,8 +94,8 @@ public TRegionReplicaSet getSchemaRegionReplicaSet(IDeviceID deviceID) { return schemaPartitionMap.get(storageGroup).get(seriesPartitionSlot); } - private String getStorageGroupByDevice(IDeviceID deviceID) { - for (String storageGroup : schemaPartitionMap.keySet()) { + private String getStorageGroupByDevice(final IDeviceID deviceID) { + for (final String storageGroup : schemaPartitionMap.keySet()) { if (PathUtils.isStartWith(deviceID, storageGroup)) { return storageGroup; } From 6cacf0442d16259140614d96ae13385828a82fa1 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 17:19:41 +0800 Subject: [PATCH 28/71] Delete database --- .../consensus/request/ConfigPhysicalPlan.java | 3 +++ .../consensus/request/ConfigPhysicalPlanType.java | 1 + .../request/write/database/DeleteDatabasePlan.java | 7 ++++--- .../pipe/extractor/ConfigRegionListeningFilter.java | 4 +++- .../receiver/protocol/IoTDBConfigNodeReceiver.java | 5 +++++ .../manager/schema/ClusterSchemaManager.java | 3 +-- .../persistence/executor/ConfigPlanExecutor.java | 13 +++++++++++-- .../persistence/partition/PartitionInfo.java | 9 ++++----- .../persistence/schema/ClusterSchemaInfo.java | 9 ++++----- .../procedure/env/ConfigNodeProcedureEnv.java | 10 +++++----- .../impl/schema/DeleteDatabaseProcedure.java | 9 +++++++-- 11 files changed, 48 insertions(+), 25 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java index 411a5b92072f..1bfbe892462b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java @@ -201,6 +201,9 @@ public static ConfigPhysicalPlan create(final ByteBuffer buffer) throws IOExcept case AlterDatabase: plan = new DatabaseSchemaPlan(ConfigPhysicalPlanType.AlterDatabase); break; + case DeleteDatabaseV2: + plan = new DatabaseSchemaPlan(ConfigPhysicalPlanType.DeleteDatabaseV2); + break; case SetTTL: plan = new SetTTLPlan(); break; diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java index 5d3bdcc6710e..f8f727081362 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java @@ -55,6 +55,7 @@ public enum ConfigPhysicalPlanType { CountDatabase((short) 209), AlterDatabase((short) 210), ShowTTL((short) 211), + DeleteDatabaseV2((short) 212), /** Region. */ CreateRegionGroups((short) 300), diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java index f026275f9fb4..29ba660c3086 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java @@ -28,6 +28,7 @@ import java.nio.ByteBuffer; import java.util.Objects; +@Deprecated public class DeleteDatabasePlan extends ConfigPhysicalPlan { private String name; @@ -36,7 +37,7 @@ public DeleteDatabasePlan() { super(ConfigPhysicalPlanType.DeleteDatabase); } - public DeleteDatabasePlan(String name) { + public DeleteDatabasePlan(final String name) { this(); this.name = name; } @@ -46,7 +47,7 @@ public String getName() { } @Override - protected void serializeImpl(DataOutputStream stream) throws IOException { + protected void serializeImpl(final DataOutputStream stream) throws IOException { stream.writeShort(getType().getPlanType()); BasicStructureSerDeUtil.write(name, stream); } @@ -57,7 +58,7 @@ protected void deserializeImpl(ByteBuffer buffer) { } @Override - public boolean equals(Object o) { + public boolean equals(final Object o) { if (this == o) { return true; } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java index 1718fcb68cfb..2035e108d091 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java @@ -67,7 +67,9 @@ public class ConfigRegionListeningFilter { Collections.singletonList(ConfigPhysicalPlanType.AlterDatabase)); OPTION_PLAN_MAP.put( new PartialPath("schema.database.drop"), - Collections.singletonList(ConfigPhysicalPlanType.DeleteDatabase)); + Collections.unmodifiableList( + Arrays.asList( + ConfigPhysicalPlanType.DeleteDatabase, ConfigPhysicalPlanType.DeleteDatabaseV2))); OPTION_PLAN_MAP.put( new PartialPath("schema.timeseries.template.create"), diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java index 5a67005110a2..418b226a4669 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java @@ -251,6 +251,11 @@ private TSStatus executePlan(final ConfigPhysicalPlan plan) throws ConsensusExce new TDeleteDatabasesReq( Collections.singletonList(((DeleteDatabasePlan) plan).getName())) .setIsGeneratedByPipe(true)); + case DeleteDatabaseV2: + return configManager.deleteDatabases( + new TDeleteDatabasesReq( + Collections.singletonList(((DatabaseSchemaPlan) plan).getSchema().getName())) + .setIsGeneratedByPipe(true)); case ExtendSchemaTemplate: return configManager .getClusterSchemaManager() diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 9d68f2e27ce2..47ac7ee8d625 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -50,7 +50,6 @@ import org.apache.iotdb.confignode.consensus.request.read.template.GetTemplateSetInfoPlan; import org.apache.iotdb.confignode.consensus.request.write.database.AdjustMaxRegionGroupNumPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; -import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetDataReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetSchemaReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetTimePartitionIntervalPlan; @@ -271,7 +270,7 @@ public TSStatus alterDatabase( /** Delete DatabaseSchema. */ public TSStatus deleteDatabase( - final DeleteDatabasePlan deleteDatabasePlan, final boolean isGeneratedByPipe) { + final DatabaseSchemaPlan deleteDatabasePlan, final boolean isGeneratedByPipe) { TSStatus result; try { result = diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java index 804be5986ecc..38ec64a63493 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java @@ -404,9 +404,18 @@ public TSStatus executeNonQueryPlan(ConfigPhysicalPlan physicalPlan) (AdjustMaxRegionGroupNumPlan) physicalPlan); case DeleteDatabase: try { - return clusterSchemaInfo.deleteDatabase((DeleteDatabasePlan) physicalPlan); + return clusterSchemaInfo.deleteDatabase( + ((DeleteDatabasePlan) physicalPlan).getName(), false); } finally { - partitionInfo.deleteDatabase((DeleteDatabasePlan) physicalPlan); + partitionInfo.deleteDatabase(((DeleteDatabasePlan) physicalPlan).getName()); + } + case DeleteDatabaseV2: + try { + final TDatabaseSchema schema = ((DatabaseSchemaPlan) physicalPlan).getSchema(); + return clusterSchemaInfo.deleteDatabase( + schema.getName(), schema.isSetIsTableModel() && schema.isIsTableModel()); + } finally { + partitionInfo.deleteDatabase(((DatabaseSchemaPlan) physicalPlan).getSchema().getName()); } case PreDeleteDatabase: return partitionInfo.preDeleteDatabase((PreDeleteDatabasePlan) physicalPlan); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index c96d4a95eeeb..943f2bcd47a5 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -38,7 +38,6 @@ import org.apache.iotdb.confignode.consensus.request.read.region.GetRegionIdPlan; import org.apache.iotdb.confignode.consensus.request.read.region.GetRegionInfoListPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; -import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.datanode.UpdateDataNodePlan; import org.apache.iotdb.confignode.consensus.request.write.partition.AddRegionLocationPlan; @@ -310,11 +309,11 @@ public boolean isDatabasePreDeleted(String database) { /** * Thread-safely delete database. * - * @param plan DeleteDatabasePlan + * @param databaseName databaseName */ - public void deleteDatabase(DeleteDatabasePlan plan) { - // Clean the databaseTable cache - databasePartitionTables.remove(plan.getName()); + public void deleteDatabase(final String databaseName) { + // Clean the StorageGroupTable cache + databasePartitionTables.remove(databaseName); } /** diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 9f5ade04063f..0fff22cf5d4d 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -44,7 +44,6 @@ import org.apache.iotdb.confignode.consensus.request.read.template.GetTemplateSetInfoPlan; import org.apache.iotdb.confignode.consensus.request.write.database.AdjustMaxRegionGroupNumPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; -import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetDataReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetSchemaReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetTimePartitionIntervalPlan; @@ -270,16 +269,16 @@ public TSStatus alterDatabase(final DatabaseSchemaPlan plan) { /** * Delete Database. * - * @param plan DeleteDatabasePlan + * @param databaseName dbName * @return {@link TSStatusCode#SUCCESS_STATUS} */ - public TSStatus deleteDatabase(final DeleteDatabasePlan plan) { + public TSStatus deleteDatabase(final String databaseName, final boolean isTableModel) { final TSStatus result = new TSStatus(); databaseReadWriteLock.writeLock().lock(); try { // Delete Database - // TODO: Use TDatabaseSchema - treeModelMTree.deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); + (isTableModel ? tableModelMTree : treeModelMTree) + .deleteDatabase(getQualifiedDatabasePartialPath(databaseName)); result.setCode(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (final MetadataException e) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java index f5cee035c2ca..663ccd0d7104 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java @@ -39,7 +39,7 @@ import org.apache.iotdb.confignode.client.sync.SyncConfigNodeClientPool; import org.apache.iotdb.confignode.client.sync.SyncDataNodeClientPool; import org.apache.iotdb.confignode.consensus.request.write.confignode.RemoveConfigNodePlan; -import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; +import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.region.CreateRegionGroupsPlan; import org.apache.iotdb.confignode.exception.AddConsensusGroupException; @@ -133,13 +133,13 @@ public ConfigManager getConfigManager() { /** * Delete ConfigNode cache, includes {@link ClusterSchemaInfo} and {@link PartitionInfo}. * - * @param name database name + * @param plan databaseSchemaPlan * @param isGeneratedByPipe whether the deletion is triggered by pipe request * @return tsStatus */ - public TSStatus deleteDatabaseConfig(final String name, final boolean isGeneratedByPipe) { - final DeleteDatabasePlan deleteDatabasePlan = new DeleteDatabasePlan(name); - return getClusterSchemaManager().deleteDatabase(deleteDatabasePlan, isGeneratedByPipe); + public TSStatus deleteDatabaseConfig( + final DatabaseSchemaPlan plan, final boolean isGeneratedByPipe) { + return getClusterSchemaManager().deleteDatabase(plan, isGeneratedByPipe); } /** diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java index 6c8a679b9f3b..19bb31d465b6 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java @@ -30,6 +30,8 @@ import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; +import org.apache.iotdb.confignode.consensus.request.ConfigPhysicalPlanType; +import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.region.OfferRegionMaintainTasksPlan; import org.apache.iotdb.confignode.manager.partition.PartitionMetrics; @@ -205,7 +207,10 @@ protected Flow executeFromState( // Delete DatabasePartitionTable final TSStatus deleteConfigResult = - env.deleteDatabaseConfig(deleteDatabaseSchema.getName(), isGeneratedByPipe); + env.deleteDatabaseConfig( + new DatabaseSchemaPlan( + ConfigPhysicalPlanType.DeleteDatabaseV2, deleteDatabaseSchema), + isGeneratedByPipe); if (deleteConfigResult.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { LOG.info( @@ -309,7 +314,7 @@ public void deserialize(final ByteBuffer byteBuffer) { @Override public boolean equals(final Object that) { if (that instanceof DeleteDatabaseProcedure) { - DeleteDatabaseProcedure thatProc = (DeleteDatabaseProcedure) that; + final DeleteDatabaseProcedure thatProc = (DeleteDatabaseProcedure) that; return thatProc.getProcId() == this.getProcId() && thatProc.getCurrentState().equals(this.getCurrentState()) && thatProc.getCycles() == this.getCycles() From 75ff3a544a9b2d3ac60cac4d9b8a924b96874769 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 17:41:11 +0800 Subject: [PATCH 29/71] Update IoTDBDatabaseIT.java --- .../org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java | 2 -- 1 file changed, 2 deletions(-) diff --git a/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java b/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java index c48f10a7f2fc..bc282384bf7c 100644 --- a/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java @@ -85,7 +85,6 @@ public void testManageDatabase() { int[] schemaReplicaFactors = new int[] {1}; int[] dataReplicaFactors = new int[] {1}; int[] timePartitionInterval = new int[] {604800000}; - String[] model = new String[] {"TABLE"}; // show try (final ResultSet resultSet = statement.executeQuery("SHOW DATABASES")) { @@ -121,7 +120,6 @@ public void testManageDatabase() { assertEquals(schemaReplicaFactors[cnt], resultSet.getInt(3)); assertEquals(dataReplicaFactors[cnt], resultSet.getInt(4)); assertEquals(timePartitionInterval[cnt], resultSet.getLong(5)); - assertEquals(model[cnt], resultSet.getString(6)); cnt++; } assertEquals(databaseNames.length, cnt); From 7489437ca28ea7412eb662585033d8f2b0d3d6c8 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 18:02:44 +0800 Subject: [PATCH 30/71] Fix --- .../org/apache/iotdb/confignode/manager/ProcedureManager.java | 2 +- .../iotdb/confignode/manager/schema/ClusterSchemaManager.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java index 4664cdd652d7..45e88eb82912 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ProcedureManager.java @@ -233,7 +233,7 @@ public TSStatus testSubProcedure() { public TSStatus deleteDatabases( final List deleteSgSchemaList, final boolean isGeneratedByPipe) { - List procedures = new ArrayList<>(); + final List procedures = new ArrayList<>(); final long startCheckTimeForProcedures = System.currentTimeMillis(); for (final TDatabaseSchema databaseSchema : deleteSgSchemaList) { final String database = databaseSchema.getName(); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 47ac7ee8d625..7dd0ea79b396 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -639,7 +639,7 @@ public Map getMatchedDatabaseSchemasByName( .getMatchedDatabaseSchemasByName(rawPathList, isTableModel) .forEach( (database, databaseSchema) -> { - if (isDatabaseExist(database)) { + if (isDatabaseExist(databaseSchema.getName())) { result.put(database, databaseSchema); } }); From 735d9811d14aab08034fd7873c338cfb01bed45b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 18:19:31 +0800 Subject: [PATCH 31/71] Fix --- .../thrift/impl/DataNodeRegionManager.java | 16 ++++--- .../iotdb/db/schemaengine/SchemaEngine.java | 42 ++++++++----------- .../schemaregion/ISchemaRegionParams.java | 3 +- .../schemaregion/SchemaRegionParams.java | 11 +++-- .../impl/SchemaRegionMemoryImpl.java | 2 +- .../impl/SchemaRegionPBTreeImpl.java | 6 +-- .../DataNodeInternalRPCServiceImplTest.java | 3 +- .../apache/iotdb/db/tools/MLogParserTest.java | 5 +-- .../utils/SchemaRegionSnapshotParserTest.java | 9 ++-- .../iotdb/commons/path/PartialPath.java | 2 +- 10 files changed, 43 insertions(+), 56 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeRegionManager.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeRegionManager.java index a6809471f4ab..250793b0e4d0 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeRegionManager.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/protocol/thrift/impl/DataNodeRegionManager.java @@ -29,7 +29,6 @@ import org.apache.iotdb.commons.consensus.SchemaRegionId; import org.apache.iotdb.commons.exception.IllegalPathException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.consensus.common.Peer; import org.apache.iotdb.consensus.exception.ConsensusException; import org.apache.iotdb.consensus.exception.ConsensusGroupAlreadyExistException; @@ -110,8 +109,7 @@ public TSStatus createSchemaRegion( final SchemaRegionId schemaRegionId = new SchemaRegionId(regionReplicaSet.getRegionId().getId()); try { - final PartialPath storageGroupPartitionPath = PartialPath.getDatabasePath(storageGroup); - schemaEngine.createSchemaRegion(storageGroupPartitionPath, schemaRegionId); + schemaEngine.createSchemaRegion(storageGroup, schemaRegionId); schemaRegionLockMap.put(schemaRegionId, new ReentrantReadWriteLock(false)); final List peers = new ArrayList<>(); for (final TDataNodeLocation dataNodeLocation : regionReplicaSet.getDataNodeLocations()) { @@ -172,20 +170,20 @@ public TSStatus createDataRegion(TRegionReplicaSet regionReplicaSet, String stor return tsStatus; } - public TSStatus createNewRegion(ConsensusGroupId regionId, String storageGroup) { - TSStatus status = new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); + public TSStatus createNewRegion(final ConsensusGroupId regionId, final String storageGroup) { + final TSStatus status = new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); LOGGER.info("start to create new region {}", regionId); try { if (regionId instanceof DataRegionId) { - DataRegionId dataRegionId = (DataRegionId) regionId; + final DataRegionId dataRegionId = (DataRegionId) regionId; storageEngine.createDataRegion(dataRegionId, storageGroup); dataRegionLockMap.put(dataRegionId, new ReentrantReadWriteLock(false)); } else { - SchemaRegionId schemaRegionId = (SchemaRegionId) regionId; - schemaEngine.createSchemaRegion(new PartialPath(storageGroup), schemaRegionId); + final SchemaRegionId schemaRegionId = (SchemaRegionId) regionId; + schemaEngine.createSchemaRegion(storageGroup, schemaRegionId); schemaRegionLockMap.put(schemaRegionId, new ReentrantReadWriteLock(false)); } - } catch (Exception e) { + } catch (final Exception e) { LOGGER.error("create new region {} error", regionId, e); status.setCode(TSStatusCode.CREATE_REGION_ERROR.getStatusCode()); status.setMessage("create new region " + regionId + "error, exception:" + e.getMessage()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java index de336b0a9df3..f55766c73f7d 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java @@ -50,6 +50,7 @@ import org.apache.iotdb.mpp.rpc.thrift.TDataNodeHeartbeatReq; import org.apache.iotdb.mpp.rpc.thrift.TDataNodeHeartbeatResp; +import org.apache.tsfile.common.constant.TsFileConstant; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -189,26 +190,19 @@ public static Map> getLocalSchemaRegionInfo() { @SuppressWarnings("java:S2142") private void initSchemaRegion() { // recover SchemaRegion concurrently - Map> localSchemaRegionInfo = getLocalSchemaRegionInfo(); + final Map> localSchemaRegionInfo = getLocalSchemaRegionInfo(); final ExecutorService schemaRegionRecoverPools = IoTDBThreadPoolFactory.newFixedThreadPool( Runtime.getRuntime().availableProcessors(), ThreadName.SCHEMA_REGION_RECOVER_TASK.getName()); final List> futures = new ArrayList<>(); localSchemaRegionInfo.forEach( - (k, v) -> { - for (SchemaRegionId schemaRegionId : v) { - PartialPath database; - try { - database = PartialPath.getDatabasePath(k); - } catch (IllegalPathException e) { - logger.warn("Illegal database path: {}", k); - continue; - } - futures.add( - schemaRegionRecoverPools.submit(recoverSchemaRegionTask(database, schemaRegionId))); - } - }); + (k, v) -> + v.forEach( + schemaRegionId -> + futures.add( + schemaRegionRecoverPools.submit( + recoverSchemaRegionTask(k, schemaRegionId))))); for (final Future future : futures) { try { final ISchemaRegion schemaRegion = future.get(); @@ -276,17 +270,17 @@ public List getAllSchemaRegionIds() { } public synchronized void createSchemaRegion( - PartialPath storageGroup, SchemaRegionId schemaRegionId) throws MetadataException { - ISchemaRegion schemaRegion = schemaRegionMap.get(schemaRegionId); + final String storageGroup, final SchemaRegionId schemaRegionId) throws MetadataException { + final ISchemaRegion schemaRegion = schemaRegionMap.get(schemaRegionId); if (schemaRegion != null) { - if (schemaRegion.getDatabaseFullPath().equals(storageGroup.getFullPath())) { + if (schemaRegion.getDatabaseFullPath().equals(storageGroup)) { return; } else { throw new MetadataException( String.format( "SchemaRegion [%s] is duplicated between [%s] and [%s], " + "and the former one has been recovered.", - schemaRegionId, schemaRegion.getDatabaseFullPath(), storageGroup.getFullPath())); + schemaRegionId, schemaRegion.getDatabaseFullPath(), storageGroup)); } } schemaRegionMap.put( @@ -294,7 +288,7 @@ public synchronized void createSchemaRegion( } private Callable recoverSchemaRegionTask( - PartialPath storageGroup, SchemaRegionId schemaRegionId) { + String storageGroup, SchemaRegionId schemaRegionId) { // this method is called for concurrent recovery of schema regions return () -> { long timeRecord = System.currentTimeMillis(); @@ -305,24 +299,24 @@ private Callable recoverSchemaRegionTask( timeRecord = System.currentTimeMillis() - timeRecord; logger.info( "Recover [{}] spend: {} ms", - storageGroup.concatNode(schemaRegionId.toString()), + storageGroup + TsFileConstant.PATH_SEPARATOR + schemaRegionId.toString(), timeRecord); return schemaRegion; } catch (MetadataException e) { logger.error( String.format( "SchemaRegion [%d] in StorageGroup [%s] failed to recover.", - schemaRegionId.getId(), storageGroup.getFullPath())); + schemaRegionId.getId(), storageGroup)); throw new RuntimeException(e); } }; } private ISchemaRegion createSchemaRegionWithoutExistenceCheck( - PartialPath database, SchemaRegionId schemaRegionId) throws MetadataException { - ISchemaRegionParams schemaRegionParams = + final String database, final SchemaRegionId schemaRegionId) throws MetadataException { + final ISchemaRegionParams schemaRegionParams = new SchemaRegionParams(database, schemaRegionId, schemaEngineStatistics); - ISchemaRegion schemaRegion = schemaRegionLoader.createSchemaRegion(schemaRegionParams); + final ISchemaRegion schemaRegion = schemaRegionLoader.createSchemaRegion(schemaRegionParams); schemaMetricManager.addSchemaRegionMetric( schemaRegionId.getId(), schemaRegion.getSchemaRegionMetric()); return schemaRegion; diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/ISchemaRegionParams.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/ISchemaRegionParams.java index c83294defcb6..6082c6a69c83 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/ISchemaRegionParams.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/ISchemaRegionParams.java @@ -20,12 +20,11 @@ package org.apache.iotdb.db.schemaengine.schemaregion; import org.apache.iotdb.commons.consensus.SchemaRegionId; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.db.schemaengine.rescon.ISchemaEngineStatistics; public interface ISchemaRegionParams { - PartialPath getDatabase(); + String getDatabase(); SchemaRegionId getSchemaRegionId(); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/SchemaRegionParams.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/SchemaRegionParams.java index fa5e3db8a73a..1d9f24bd34c9 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/SchemaRegionParams.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/SchemaRegionParams.java @@ -20,28 +20,27 @@ package org.apache.iotdb.db.schemaengine.schemaregion; import org.apache.iotdb.commons.consensus.SchemaRegionId; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.db.schemaengine.rescon.ISchemaEngineStatistics; public class SchemaRegionParams implements ISchemaRegionParams { - private final PartialPath database; + private final String database; private final SchemaRegionId schemaRegionId; private final ISchemaEngineStatistics schemaEngineStatistics; public SchemaRegionParams( - PartialPath database, - SchemaRegionId schemaRegionId, - ISchemaEngineStatistics schemaEngineStatistics) { + final String database, + final SchemaRegionId schemaRegionId, + final ISchemaEngineStatistics schemaEngineStatistics) { this.database = database; this.schemaRegionId = schemaRegionId; this.schemaEngineStatistics = schemaEngineStatistics; } @Override - public PartialPath getDatabase() { + public String getDatabase() { return database; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java index f86bf5f56075..13624cafb335 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionMemoryImpl.java @@ -216,7 +216,7 @@ public class SchemaRegionMemoryImpl implements ISchemaRegion { public SchemaRegionMemoryImpl(final ISchemaRegionParams schemaRegionParams) throws MetadataException { - storageGroupFullPath = schemaRegionParams.getDatabase().getFullPath(); + storageGroupFullPath = schemaRegionParams.getDatabase(); this.schemaRegionId = schemaRegionParams.getSchemaRegionId(); storageGroupDirPath = config.getSchemaDir() + File.separator + storageGroupFullPath; diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionPBTreeImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionPBTreeImpl.java index 5e09c9e4a1a1..85038d219083 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionPBTreeImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/schemaregion/impl/SchemaRegionPBTreeImpl.java @@ -182,7 +182,7 @@ public class SchemaRegionPBTreeImpl implements ISchemaRegion { // region Interfaces and Implementation of initialization、snapshot、recover and clear public SchemaRegionPBTreeImpl(ISchemaRegionParams schemaRegionParams) throws MetadataException { - storageGroupFullPath = schemaRegionParams.getDatabase().getFullPath(); + storageGroupFullPath = schemaRegionParams.getDatabase(); this.schemaRegionId = schemaRegionParams.getSchemaRegionId(); storageGroupDirPath = config.getSchemaDir() + File.separator + storageGroupFullPath; @@ -190,9 +190,7 @@ public SchemaRegionPBTreeImpl(ISchemaRegionParams schemaRegionParams) throws Met this.regionStatistics = new CachedSchemaRegionStatistics( schemaRegionId.getId(), schemaRegionParams.getSchemaEngineStatistics()); - this.metric = - new SchemaRegionCachedMetric( - regionStatistics, schemaRegionParams.getDatabase().getFullPath()); + this.metric = new SchemaRegionCachedMetric(regionStatistics, schemaRegionParams.getDatabase()); init(); } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/service/DataNodeInternalRPCServiceImplTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/service/DataNodeInternalRPCServiceImplTest.java index b80057b43c1f..0ecca76aa845 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/service/DataNodeInternalRPCServiceImplTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/service/DataNodeInternalRPCServiceImplTest.java @@ -80,8 +80,7 @@ public static void setUpBeforeClass() throws IOException, MetadataException { conf.setDataNodeId(dataNodeId); SchemaEngine.getInstance().init(); - SchemaEngine.getInstance() - .createSchemaRegion(new PartialPath("root.ln"), new SchemaRegionId(0)); + SchemaEngine.getInstance().createSchemaRegion("root.ln", new SchemaRegionId(0)); DataRegionConsensusImpl.getInstance().start(); SchemaRegionConsensusImpl.getInstance().start(); DataNodeRegionManager.getInstance().init(); diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/tools/MLogParserTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/tools/MLogParserTest.java index 7d6149810eb8..244e1d459f9e 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/tools/MLogParserTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/tools/MLogParserTest.java @@ -91,8 +91,7 @@ private void prepareData() throws Exception { SchemaEngine schemaEngine = SchemaEngine.getInstance(); for (int i = 0; i < storageGroups.length; i++) { SchemaEngine.getInstance() - .createSchemaRegion( - new PartialPath(storageGroups[i]), new SchemaRegionId(schemaRegionIds[i])); + .createSchemaRegion(storageGroups[i], new SchemaRegionId(schemaRegionIds[i])); } for (int i = 0; i < 2; i++) { @@ -140,7 +139,7 @@ private void prepareData() throws Exception { try { SchemaEngine.getInstance() - .createSchemaRegion(new PartialPath("root.sg"), new SchemaRegionId(schemaRegionIds[2])); + .createSchemaRegion("root.sg", new SchemaRegionId(schemaRegionIds[2])); } catch (MetadataException e) { e.printStackTrace(); } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java index 1a3454192b14..3da5effd5b3e 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java @@ -129,14 +129,15 @@ protected void cleanEnv() throws IOException { FileUtils.deleteDirectory(new File(IoTDBDescriptor.getInstance().getConfig().getSchemaDir())); } - public SchemaRegionSnapshotParserTest(SchemaRegionSnapshotParserTestParams params) { + public SchemaRegionSnapshotParserTest(final SchemaRegionSnapshotParserTestParams params) { this.testParams = params; } - public ISchemaRegion getSchemaRegion(String database, int schemaRegionId) throws Exception { - SchemaRegionId regionId = new SchemaRegionId(schemaRegionId); + public ISchemaRegion getSchemaRegion(final String database, final int schemaRegionId) + throws Exception { + final SchemaRegionId regionId = new SchemaRegionId(schemaRegionId); if (SchemaEngine.getInstance().getSchemaRegion(regionId) == null) { - SchemaEngine.getInstance().createSchemaRegion(new PartialPath(database), regionId); + SchemaEngine.getInstance().createSchemaRegion(database, regionId); } return SchemaEngine.getInstance().getSchemaRegion(regionId); } diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java index c61d3101506b..1b7163ca6004 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/path/PartialPath.java @@ -66,7 +66,7 @@ public class PartialPath extends Path implements Comparable, Cloneable { public PartialPath() {} - public PartialPath(IDeviceID device) throws IllegalPathException { + public PartialPath(final IDeviceID device) throws IllegalPathException { // the first segment is the table name, which may contain multiple levels String[] tableNameSegments = PathUtils.splitPathToDetachedNodes(device.getTableName()); nodes = new String[device.segmentNum() - 1 + tableNameSegments.length]; From afcdad2f920a8e254544d52934cd341c02272427 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 18:28:20 +0800 Subject: [PATCH 32/71] Update AbstractSchemaRegionTest.java --- .../db/metadata/schemaRegion/AbstractSchemaRegionTest.java | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/AbstractSchemaRegionTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/AbstractSchemaRegionTest.java index 15a05971eb76..f438d256e532 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/AbstractSchemaRegionTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/AbstractSchemaRegionTest.java @@ -22,7 +22,6 @@ import org.apache.iotdb.commons.conf.CommonConfig; import org.apache.iotdb.commons.conf.CommonDescriptor; import org.apache.iotdb.commons.consensus.SchemaRegionId; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; import org.apache.iotdb.db.schemaengine.SchemaEngine; @@ -95,8 +94,7 @@ protected ISchemaRegion getSchemaRegion(final String database, final int schemaR throws Exception { final SchemaRegionId regionId = new SchemaRegionId(schemaRegionId); if (SchemaEngine.getInstance().getSchemaRegion(regionId) == null) { - SchemaEngine.getInstance() - .createSchemaRegion(PartialPath.getDatabasePath(database), regionId); + SchemaEngine.getInstance().createSchemaRegion(database, regionId); } return SchemaEngine.getInstance().getSchemaRegion(regionId); } From c1a616278372976c87daa789e0530e6d27b42f64 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 18:57:43 +0800 Subject: [PATCH 33/71] Fix --- .../schema/TableDeviceAttributeUpdateNode.java | 9 +-------- .../iotdb/db/schemaengine/SchemaEngine.java | 18 +++++------------- 2 files changed, 6 insertions(+), 21 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/TableDeviceAttributeUpdateNode.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/TableDeviceAttributeUpdateNode.java index 3932db6a3ff0..4ecc483b5185 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/TableDeviceAttributeUpdateNode.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/node/schema/TableDeviceAttributeUpdateNode.java @@ -48,9 +48,6 @@ import java.util.Objects; import java.util.stream.Collectors; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_ROOT; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_SEPARATOR; - public class TableDeviceAttributeUpdateNode extends WritePlanNode implements ISchemaRegionPlan { protected String database; @@ -322,11 +319,7 @@ public TRegionReplicaSet getRegionReplicaSet() { @Override public List splitByPartition(final IAnalysis analysis) { return new HashSet<>( - analysis - .getSchemaPartitionInfo() - .getSchemaPartitionMap() - .get(PATH_ROOT + PATH_SEPARATOR + database) - .values()) + analysis.getSchemaPartitionInfo().getSchemaPartitionMap().get(database).values()) .stream() .map( replicaSet -> diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java index f55766c73f7d..cfbb2807d77c 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java @@ -149,15 +149,7 @@ public static Map> getLocalSchemaRegionInfo() { continue; } - final PartialPath database; - try { - database = PartialPath.getDatabasePath(file.getName()); - } catch (IllegalPathException illegalPathException) { - // not a legal sg dir - continue; - } - - final File sgDir = new File(config.getSchemaDir(), database.getFullPath()); + final File sgDir = new File(config.getSchemaDir(), file.getName()); if (!sgDir.exists()) { continue; @@ -178,7 +170,7 @@ public static Map> getLocalSchemaRegionInfo() { } schemaRegionIds.add(schemaRegionId); } - localSchemaPartitionTable.put(database.getFullPath(), schemaRegionIds); + localSchemaPartitionTable.put(file.getName(), schemaRegionIds); } return localSchemaPartitionTable; } @@ -257,7 +249,7 @@ public void clear() { ClusterTemplateManager.getInstance().clear(); } - public ISchemaRegion getSchemaRegion(SchemaRegionId regionId) { + public ISchemaRegion getSchemaRegion(final SchemaRegionId regionId) { return schemaRegionMap.get(regionId); } @@ -288,7 +280,7 @@ public synchronized void createSchemaRegion( } private Callable recoverSchemaRegionTask( - String storageGroup, SchemaRegionId schemaRegionId) { + final String storageGroup, final SchemaRegionId schemaRegionId) { // this method is called for concurrent recovery of schema regions return () -> { long timeRecord = System.currentTimeMillis(); @@ -302,7 +294,7 @@ private Callable recoverSchemaRegionTask( storageGroup + TsFileConstant.PATH_SEPARATOR + schemaRegionId.toString(), timeRecord); return schemaRegion; - } catch (MetadataException e) { + } catch (final MetadataException e) { logger.error( String.format( "SchemaRegion [%d] in StorageGroup [%s] failed to recover.", From c4757b9537e5597032dc13721cacff1204bf78bb Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 19:03:09 +0800 Subject: [PATCH 34/71] Fix --- .../schema/table/CreateTableProcedure.java | 5 +-- .../plan/analyze/AnalyzeVisitor.java | 21 ---------- .../iotdb/db/schemaengine/SchemaEngine.java | 4 +- .../table/DataNodeTableCache.java | 41 ------------------- 4 files changed, 2 insertions(+), 69 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java index 56c2fb9c4fc3..4ef4f0c11635 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/CreateTableProcedure.java @@ -48,7 +48,6 @@ import java.util.Map; import java.util.Objects; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; import static org.apache.iotdb.rpc.TSStatusCode.TABLE_ALREADY_EXISTS; public class CreateTableProcedure @@ -119,9 +118,7 @@ private void checkTableExistence(final ConfigNodeProcedureEnv env) { setFailure( new ProcedureException( new IoTDBException( - String.format( - "Table '%s.%s' already exists.", - database.substring(ROOT.length() + 1), table.getTableName()), + String.format("Table '%s.%s' already exists.", database, table.getTableName()), TABLE_ALREADY_EXISTS.getStatusCode()))); } else { final TDatabaseSchema schema = diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeVisitor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeVisitor.java index 224d22520a0a..bc8959eb5009 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeVisitor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeVisitor.java @@ -45,7 +45,6 @@ import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; import org.apache.iotdb.db.exception.ainode.GetModelInfoException; -import org.apache.iotdb.db.exception.metadata.table.TableAlreadyExistsException; import org.apache.iotdb.db.exception.metadata.template.TemplateIncompatibleException; import org.apache.iotdb.db.exception.metadata.view.UnsupportedViewException; import org.apache.iotdb.db.exception.sql.SemanticException; @@ -160,7 +159,6 @@ import org.apache.iotdb.db.queryengine.plan.statement.sys.ExplainStatement; import org.apache.iotdb.db.queryengine.plan.statement.sys.ShowQueriesStatement; import org.apache.iotdb.db.queryengine.plan.statement.sys.ShowVersionStatement; -import org.apache.iotdb.db.schemaengine.table.DataNodeTableCache; import org.apache.iotdb.db.schemaengine.template.Template; import org.apache.iotdb.db.storageengine.load.config.LoadTsFileConfigurator; import org.apache.iotdb.db.storageengine.load.metrics.LoadTsFileCostMetricsSet; @@ -2603,7 +2601,6 @@ public Analysis visitCreateTimeseries( Analysis analysis = new Analysis(); analysis.setRealStatement(createTimeSeriesStatement); - checkIsTableCompatible(createTimeSeriesStatement.getPath(), context, true); checkIsTemplateCompatible( createTimeSeriesStatement.getPath(), createTimeSeriesStatement.getAlias(), context, true); @@ -2659,19 +2656,6 @@ private void checkIsTemplateCompatible( } } - private void checkIsTableCompatible( - final PartialPath timeSeriesPath, final MPPQueryContext context, final boolean takeLock) { - if (takeLock) { - DataNodeSchemaLockManager.getInstance() - .takeReadLock(context, SchemaLockType.TIMESERIES_VS_TABLE); - } - final Pair tableInfo = - DataNodeTableCache.getInstance().checkTableCreateAndPreCreateOnGivenPath(timeSeriesPath); - if (tableInfo != null) { - throw new SemanticException(new TableAlreadyExistsException(tableInfo.left, tableInfo.right)); - } - } - private void analyzeSchemaProps(final Map props) { if (props == null || props.isEmpty()) { return; @@ -2721,7 +2705,6 @@ public Analysis visitCreateAlignedTimeseries( Analysis analysis = new Analysis(); analysis.setRealStatement(createAlignedTimeSeriesStatement); - checkIsTableCompatible(createAlignedTimeSeriesStatement.getDevicePath(), context, true); checkIsTemplateCompatible( createAlignedTimeSeriesStatement.getDevicePath(), createAlignedTimeSeriesStatement.getMeasurements(), @@ -2750,7 +2733,6 @@ public Analysis visitInternalCreateTimeseries( Analysis analysis = new Analysis(); analysis.setRealStatement(internalCreateTimeSeriesStatement); - checkIsTableCompatible(internalCreateTimeSeriesStatement.getDevicePath(), context, true); checkIsTemplateCompatible( internalCreateTimeSeriesStatement.getDevicePath(), internalCreateTimeSeriesStatement.getMeasurements(), @@ -2788,7 +2770,6 @@ public Analysis visitInternalCreateMultiTimeSeries( .takeReadLock(context, SchemaLockType.TIMESERIES_VS_TEMPLATE); for (final Map.Entry> entry : internalCreateMultiTimeSeriesStatement.getDeviceMap().entrySet()) { - checkIsTableCompatible(entry.getKey(), context, false); checkIsTemplateCompatible( entry.getKey(), entry.getValue().right.getMeasurements(), null, context, false); pathPatternTree.appendFullPath(entry.getKey().concatNode(ONE_LEVEL_PATH_WILDCARD)); @@ -2820,7 +2801,6 @@ public Analysis visitCreateMultiTimeSeries( DataNodeSchemaLockManager.getInstance() .takeReadLock(context, SchemaLockType.TIMESERIES_VS_TEMPLATE); for (int i = 0; i < timeseriesPathList.size(); i++) { - checkIsTableCompatible(timeseriesPathList.get(i), context, false); checkIsTemplateCompatible( timeseriesPathList.get(i), aliasList == null ? null : aliasList.get(i), context, false); } @@ -4087,7 +4067,6 @@ private void checkTargetPathsInCreateLogicalView( DataNodeSchemaLockManager.getInstance() .takeReadLock(context, SchemaLockType.TIMESERIES_VS_TEMPLATE); for (final PartialPath path : createLogicalViewStatement.getTargetPathList()) { - checkIsTableCompatible(path, context, false); checkIsTemplateCompatible(path, null, context, false); } } catch (final Exception e) { diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java index cfbb2807d77c..4608e52c29a2 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/SchemaEngine.java @@ -24,9 +24,7 @@ import org.apache.iotdb.commons.concurrent.threadpool.ScheduledExecutorUtil; import org.apache.iotdb.commons.conf.CommonDescriptor; import org.apache.iotdb.commons.consensus.SchemaRegionId; -import org.apache.iotdb.commons.exception.IllegalPathException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.commons.schema.table.TsTable; import org.apache.iotdb.commons.utils.FileUtils; import org.apache.iotdb.commons.utils.PathUtils; @@ -280,7 +278,7 @@ public synchronized void createSchemaRegion( } private Callable recoverSchemaRegionTask( - final String storageGroup, final SchemaRegionId schemaRegionId) { + final String storageGroup, final SchemaRegionId schemaRegionId) { // this method is called for concurrent recovery of schema regions return () -> { long timeRecord = System.currentTimeMillis(); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java index d2c31f1f3d54..61d2ecd70fad 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/schemaengine/table/DataNodeTableCache.java @@ -19,7 +19,6 @@ package org.apache.iotdb.db.schemaengine.table; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.commons.schema.table.TsTable; import org.apache.iotdb.commons.schema.table.TsTableInternalRPCUtil; import org.apache.iotdb.commons.utils.PathUtils; @@ -47,9 +46,6 @@ import java.util.function.Function; import java.util.stream.Collectors; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_ROOT; -import static org.apache.iotdb.commons.conf.IoTDBConstant.PATH_SEPARATOR; - /** It contains all tables' latest column schema */ public class DataNodeTableCache implements ITableCache { @@ -406,41 +402,4 @@ public String tryGetInternColumnName( return null; } } - - /** Check whether the given path overlap with some table existence. */ - public Pair checkTableCreateAndPreCreateOnGivenPath(final PartialPath path) { - readWriteLock.writeLock().lock(); - try { - final String pathString = path.getFullPath(); - Pair result = checkTableExistenceOnGivenPath(pathString, databaseTableMap); - if (result == null) { - result = checkTableExistenceOnGivenPath(pathString, preUpdateTableMap); - } - return result; - } finally { - readWriteLock.writeLock().unlock(); - } - } - - private Pair checkTableExistenceOnGivenPath( - final String path, final Map> tableMap) { - final int dbStartIndex = PATH_ROOT.length() + 1; - for (final Map.Entry> dbEntry : tableMap.entrySet()) { - final String database = dbEntry.getKey(); - if (!(path.startsWith(database, dbStartIndex) - && path.length() > dbStartIndex + database.length() - && path.charAt(dbStartIndex + database.length()) == PATH_SEPARATOR)) { - continue; - } - final int tableStartIndex = dbStartIndex + database.length() + 1; - for (final String tableName : dbEntry.getValue().keySet()) { - if (path.startsWith(tableName, tableStartIndex) - && path.length() > tableStartIndex + tableName.length() - && path.charAt(tableStartIndex + tableName.length()) == PATH_SEPARATOR) { - return new Pair<>(database, tableName); - } - } - } - return null; - } } From 1b468ba4a6a3347832b9215d4ed44b9c77a0926b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 20:29:48 +0800 Subject: [PATCH 35/71] Flush --- .../it/db/it/IoTDBFlushQueryTableIT.java | 8 ++--- .../manager/partition/PartitionManager.java | 18 ++++------ .../thrift/ConfigNodeRPCServiceProcessor.java | 14 ++++---- .../config/TableConfigTaskVisitor.java | 2 +- .../executor/ClusterConfigTaskExecutor.java | 11 ++++--- .../plan/execution/config/sys/FlushTask.java | 18 +++------- .../queryengine/plan/parser/ASTVisitor.java | 12 +++---- .../plan/relational/sql/ast/Flush.java | 4 +-- .../relational/sql/parser/AstBuilder.java | 20 ++++------- .../plan/statement/sys/FlushStatement.java | 33 ++++++++++++------- 10 files changed, 64 insertions(+), 76 deletions(-) diff --git a/integration-test/src/test/java/org/apache/iotdb/relational/it/db/it/IoTDBFlushQueryTableIT.java b/integration-test/src/test/java/org/apache/iotdb/relational/it/db/it/IoTDBFlushQueryTableIT.java index d69fbd9892fc..6a1207d91cdf 100644 --- a/integration-test/src/test/java/org/apache/iotdb/relational/it/db/it/IoTDBFlushQueryTableIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/relational/it/db/it/IoTDBFlushQueryTableIT.java @@ -181,15 +181,15 @@ public void testFlushGivenGroupNoData() { @Test @Ignore public void testFlushNotExistGroupNoData() { - try (Connection connection = EnvFactory.getEnv().getConnection(); - Statement statement = connection.createStatement()) { + try (final Connection connection = EnvFactory.getEnv().getConnection(); + final Statement statement = connection.createStatement()) { statement.execute("CREATE DATABASE root.noexist.nodatagroup1"); try { statement.execute( "FLUSH root.noexist.nodatagroup1,root.notExistGroup1,root.notExistGroup2"); - } catch (SQLException sqe) { + } catch (final SQLException sqe) { String expectedMsg = - "322: 322: storageGroup root.notExistGroup1,root.notExistGroup2 does not exist"; + "322: 322: Database root.notExistGroup1,root.notExistGroup2 does not exist"; sqe.printStackTrace(); assertTrue(sqe.getMessage().contains(expectedMsg)); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index 8a5bf0269383..22d8ffad02ac 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -33,7 +33,6 @@ import org.apache.iotdb.commons.partition.DataPartitionTable; import org.apache.iotdb.commons.partition.SchemaPartitionTable; import org.apache.iotdb.commons.partition.executor.SeriesPartitionExecutor; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; @@ -851,17 +850,12 @@ public boolean isDatabaseExist(final String database) { * @param databases the Databases to check * @return List of PartialPath the Databases that not exist */ - public List filterUnExistDatabases(final List databases) { - final List unExistDatabases = new ArrayList<>(); - if (databases == null) { - return unExistDatabases; - } - for (final PartialPath database : databases) { - if (!isDatabaseExist(database.getFullPath())) { - unExistDatabases.add(database); - } - } - return unExistDatabases; + public List filterUnExistDatabases(final List databases) { + return Objects.isNull(databases) + ? Collections.emptyList() + : databases.stream() + .filter(database -> !isDatabaseExist(database)) + .collect(Collectors.toList()); } /** diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index b9b62cc62804..8221d365b20b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -916,18 +916,16 @@ public TSStatus merge() throws TException { } @Override - public TSStatus flush(TFlushReq req) throws TException { + public TSStatus flush(final TFlushReq req) throws TException { if (req.storageGroups != null) { - List noExistSg = - configManager - .getPartitionManager() - .filterUnExistDatabases(PartialPath.fromStringList(req.storageGroups)); + final List noExistSg = + configManager.getPartitionManager().filterUnExistDatabases(req.storageGroups); if (!noExistSg.isEmpty()) { - StringBuilder sb = new StringBuilder(); - noExistSg.forEach(storageGroup -> sb.append(storageGroup.getFullPath()).append(",")); + final StringBuilder sb = new StringBuilder(); + noExistSg.forEach(storageGroup -> sb.append(storageGroup).append(",")); return RpcUtils.getStatus( TSStatusCode.DATABASE_NOT_EXIST, - "storageGroup " + sb.subSequence(0, sb.length() - 1) + " does not exist"); + "Database " + sb.subSequence(0, sb.length() - 1) + " does not exist"); } } return configManager.flush(req); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java index f69ca1235c83..26f82cb297e5 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java @@ -625,7 +625,7 @@ protected IConfigTask visitDescribeTable( } @Override - protected IConfigTask visitFlush(Flush node, MPPQueryContext context) { + protected IConfigTask visitFlush(final Flush node, final MPPQueryContext context) { context.setQueryType(QueryType.WRITE); accessControl.checkUserHasMaintainPrivilege(context.getSession().getUserName()); return new FlushTask(((FlushStatement) node.getInnerTreeStatement())); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 1860102ff2aa..b688a928bd49 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -1083,22 +1083,23 @@ public SettableFuture merge(boolean onCluster) { } @Override - public SettableFuture flush(TFlushReq tFlushReq, boolean onCluster) { - SettableFuture future = SettableFuture.create(); + public SettableFuture flush( + final TFlushReq tFlushReq, final boolean onCluster) { + final SettableFuture future = SettableFuture.create(); TSStatus tsStatus = new TSStatus(); if (onCluster) { - try (ConfigNodeClient client = + try (final ConfigNodeClient client = CONFIG_NODE_CLIENT_MANAGER.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { // Send request to some API server tsStatus = client.flush(tFlushReq); - } catch (ClientManagerException | TException e) { + } catch (final ClientManagerException | TException e) { future.setException(e); } } else { try { StorageEngine.getInstance().operateFlush(tFlushReq); tsStatus = RpcUtils.getStatus(TSStatusCode.SUCCESS_STATUS); - } catch (Exception e) { + } catch (final Exception e) { tsStatus = RpcUtils.getStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR, e.getMessage()); } } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/sys/FlushTask.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/sys/FlushTask.java index 69df99a92581..b4b58224f900 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/sys/FlushTask.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/sys/FlushTask.java @@ -20,7 +20,6 @@ package org.apache.iotdb.db.queryengine.plan.execution.config.sys; import org.apache.iotdb.common.rpc.thrift.TFlushReq; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.db.queryengine.plan.execution.config.ConfigTaskResult; import org.apache.iotdb.db.queryengine.plan.execution.config.IConfigTask; import org.apache.iotdb.db.queryengine.plan.execution.config.executor.IConfigTaskExecutor; @@ -28,27 +27,20 @@ import com.google.common.util.concurrent.ListenableFuture; -import java.util.ArrayList; -import java.util.List; - public class FlushTask implements IConfigTask { private final FlushStatement flushStatement; - public FlushTask(FlushStatement flushStatement) { + public FlushTask(final FlushStatement flushStatement) { this.flushStatement = flushStatement; } @Override - public ListenableFuture execute(IConfigTaskExecutor configTaskExecutor) + public ListenableFuture execute(final IConfigTaskExecutor configTaskExecutor) throws InterruptedException { - TFlushReq tFlushReq = new TFlushReq(); - List storageGroups = new ArrayList<>(); - if (flushStatement.getStorageGroups() != null) { - for (PartialPath partialPath : flushStatement.getStorageGroups()) { - storageGroups.add(partialPath.getFullPath()); - } - tFlushReq.setStorageGroups(storageGroups); + final TFlushReq tFlushReq = new TFlushReq(); + if (flushStatement.getDatabases() != null) { + tFlushReq.setStorageGroups(flushStatement.getDatabases()); } if (flushStatement.isSeq() != null) { tFlushReq.setIsSeq(flushStatement.isSeq().toString()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/parser/ASTVisitor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/parser/ASTVisitor.java index 60bfcb81cd0a..207ff7522a73 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/parser/ASTVisitor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/parser/ASTVisitor.java @@ -3329,20 +3329,20 @@ private String parseAttributeValue(IoTDBSqlParser.AttributeValueContext ctx) { // Flush @Override - public Statement visitFlush(IoTDBSqlParser.FlushContext ctx) { - FlushStatement flushStatement = new FlushStatement(StatementType.FLUSH); - List storageGroups = null; + public Statement visitFlush(final IoTDBSqlParser.FlushContext ctx) { + final FlushStatement flushStatement = new FlushStatement(StatementType.FLUSH); + List storageGroups = null; if (ctx.boolean_literal() != null) { flushStatement.setSeq(Boolean.parseBoolean(ctx.boolean_literal().getText())); } flushStatement.setOnCluster(ctx.LOCAL() == null); if (ctx.prefixPath(0) != null) { storageGroups = new ArrayList<>(); - for (IoTDBSqlParser.PrefixPathContext prefixPathContext : ctx.prefixPath()) { - storageGroups.add(parsePrefixPath(prefixPathContext)); + for (final IoTDBSqlParser.PrefixPathContext prefixPathContext : ctx.prefixPath()) { + storageGroups.add(parsePrefixPath(prefixPathContext).getFullPath()); } } - flushStatement.setStorageGroups(storageGroups); + flushStatement.setDatabases(storageGroups); return flushStatement; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/ast/Flush.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/ast/Flush.java index 608d4e34ce8e..a005a121c6a7 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/ast/Flush.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/ast/Flush.java @@ -24,12 +24,12 @@ public class Flush extends WrappedStatement { - public Flush(Statement innerTreeStatement, MPPQueryContext context) { + public Flush(final Statement innerTreeStatement, final MPPQueryContext context) { super(innerTreeStatement, context); } @Override - public R accept(AstVisitor visitor, C context) { + public R accept(final AstVisitor visitor, final C context) { return visitor.visitFlush(this, context); } } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java index 8bc0f7524b83..3536fbf7ccf0 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/sql/parser/AstBuilder.java @@ -28,7 +28,6 @@ import org.apache.iotdb.commons.schema.table.column.TsTableColumnSchema; import org.apache.iotdb.commons.udf.builtin.relational.TableBuiltinScalarFunction; import org.apache.iotdb.commons.utils.CommonDateTimeUtils; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.exception.query.QueryProcessException; import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.protocol.session.IClientSession; @@ -1121,26 +1120,19 @@ public Node visitMigrateRegionStatement(RelationalSqlParser.MigrateRegionStateme } @Override - public Node visitFlushStatement(RelationalSqlParser.FlushStatementContext ctx) { - FlushStatement flushStatement = new FlushStatement(StatementType.FLUSH); - List storageGroups = null; + public Node visitFlushStatement(final RelationalSqlParser.FlushStatementContext ctx) { + final FlushStatement flushStatement = new FlushStatement(StatementType.FLUSH); + List storageGroups = null; if (ctx.booleanValue() != null) { flushStatement.setSeq(Boolean.parseBoolean(ctx.booleanValue().getText())); } flushStatement.setOnCluster( ctx.localOrClusterMode() == null || ctx.localOrClusterMode().LOCAL() == null); if (ctx.identifier() != null) { - storageGroups = new ArrayList<>(); - List identifiers = getIdentifiers(ctx.identifier()); - for (Identifier identifier : identifiers) { - try { - storageGroups.add(new PartialPath(PathUtils.qualifyDatabaseName(identifier.getValue()))); - } catch (IllegalPathException e) { - throw new RuntimeException(e); - } - } + storageGroups = + getIdentifiers(ctx.identifier()).stream().map(Identifier::getValue).collect(toList()); } - flushStatement.setStorageGroups(storageGroups); + flushStatement.setDatabases(storageGroups); return new Flush(flushStatement, null); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/sys/FlushStatement.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/sys/FlushStatement.java index b16aaa2ed6b2..24d5458a1f00 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/sys/FlushStatement.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/statement/sys/FlushStatement.java @@ -19,6 +19,7 @@ package org.apache.iotdb.db.queryengine.plan.statement.sys; +import org.apache.iotdb.commons.exception.IllegalPathException; import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.db.queryengine.plan.analyze.QueryType; import org.apache.iotdb.db.queryengine.plan.statement.IConfigStatement; @@ -26,36 +27,37 @@ import org.apache.iotdb.db.queryengine.plan.statement.StatementType; import org.apache.iotdb.db.queryengine.plan.statement.StatementVisitor; +import java.util.ArrayList; import java.util.Collections; import java.util.List; public class FlushStatement extends Statement implements IConfigStatement { /** list of database */ - private List storageGroups; + private List databases; // being null indicates flushing both seq and unseq data private Boolean isSeq; private boolean onCluster; - public FlushStatement(StatementType flushType) { + public FlushStatement(final StatementType flushType) { this.statementType = flushType; } - public List getStorageGroups() { - return storageGroups; + public List getDatabases() { + return databases; } - public void setStorageGroups(List storageGroups) { - this.storageGroups = storageGroups; + public void setDatabases(final List databases) { + this.databases = databases; } public Boolean isSeq() { return isSeq; } - public void setSeq(Boolean seq) { + public void setSeq(final Boolean seq) { isSeq = seq; } @@ -63,7 +65,7 @@ public boolean isOnCluster() { return onCluster; } - public void setOnCluster(boolean onCluster) { + public void setOnCluster(final boolean onCluster) { this.onCluster = onCluster; } @@ -74,14 +76,23 @@ public QueryType getQueryType() { @Override public List getPaths() { - if (storageGroups == null) { + if (databases == null) { return Collections.emptyList(); } - return storageGroups; + + final List paths = new ArrayList<>(databases.size()); + try { + for (final String database : databases) { + paths.add(new PartialPath(database)); + } + } catch (final IllegalPathException e) { + // ignore + } + return paths; } @Override - public R accept(StatementVisitor visitor, C context) { + public R accept(final StatementVisitor visitor, final C context) { return visitor.visitFlush(this, context); } } From 2193dd4db4e326cb1c002610605a583aebd4d6d3 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 20:31:09 +0800 Subject: [PATCH 36/71] Update IoTDBSimpleQueryIT.java --- .../src/test/java/org/apache/iotdb/db/it/IoTDBSimpleQueryIT.java | 1 - 1 file changed, 1 deletion(-) diff --git a/integration-test/src/test/java/org/apache/iotdb/db/it/IoTDBSimpleQueryIT.java b/integration-test/src/test/java/org/apache/iotdb/db/it/IoTDBSimpleQueryIT.java index 397018804736..f404046d28a3 100644 --- a/integration-test/src/test/java/org/apache/iotdb/db/it/IoTDBSimpleQueryIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/db/it/IoTDBSimpleQueryIT.java @@ -1054,7 +1054,6 @@ public void testStorageGroupWithHyphenInName() { try (final ResultSet resultSet = statement.executeQuery("SHOW DATABASES DETAILS")) { while (resultSet.next()) { Assert.assertEquals("root.group_with_hyphen", resultSet.getString(1)); - Assert.assertEquals("TREE", resultSet.getString(12)); } } } catch (final SQLException e) { From f81708b4bb1c318aa83eaeeb909a7d53f878620d Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 20:35:15 +0800 Subject: [PATCH 37/71] Update IoTDBDeleteStorageGroupIT.java --- .../apache/iotdb/db/it/schema/IoTDBDeleteStorageGroupIT.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/integration-test/src/test/java/org/apache/iotdb/db/it/schema/IoTDBDeleteStorageGroupIT.java b/integration-test/src/test/java/org/apache/iotdb/db/it/schema/IoTDBDeleteStorageGroupIT.java index c751f6f57221..5315bd08c4d3 100644 --- a/integration-test/src/test/java/org/apache/iotdb/db/it/schema/IoTDBDeleteStorageGroupIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/db/it/schema/IoTDBDeleteStorageGroupIT.java @@ -114,8 +114,8 @@ public void testDeleteMultipleStorageGroupWithQuote() throws Exception { @Test(expected = SQLException.class) public void deleteNonExistStorageGroup() throws Exception { - try (Connection connection = EnvFactory.getEnv().getConnection(); - Statement statement = connection.createStatement()) { + try (final Connection connection = EnvFactory.getEnv().getConnection(); + final Statement statement = connection.createStatement()) { statement.execute("CREATE DATABASE root.ln2.wf01.wt01"); statement.execute("DELETE DATABASE root.ln2.wf01.wt02"); } From aea5c9ee62cd32fb2b2762519b29e2df21d77b8f Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 20:37:38 +0800 Subject: [PATCH 38/71] Update ConfigManager.java --- .../iotdb/confignode/manager/ConfigManager.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index 04c4385841fc..df7686e7a9e5 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -745,13 +745,20 @@ public synchronized TSStatus deleteDatabases(final TDeleteDatabasesReq tDeleteRe final TSStatus status = confirmLeader(); if (status.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { final List deletedPaths = tDeleteReq.getPrefixPathList(); + // remove wild + final Map deleteDatabaseSchemaMap = + getClusterSchemaManager() + .getMatchedDatabaseSchemasByName( + deletedPaths, tDeleteReq.isSetIsTableModel() && tDeleteReq.isIsTableModel()); + if (deleteDatabaseSchemaMap.isEmpty()) { + return RpcUtils.getStatus( + TSStatusCode.PATH_NOT_EXIST.getStatusCode(), + String.format("Path %s does not exist", Arrays.toString(deletedPaths.toArray()))); + } + return procedureManager.deleteDatabases( - new ArrayList<>( - getClusterSchemaManager() - .getMatchedDatabaseSchemasByName( - deletedPaths, tDeleteReq.isSetIsTableModel() && tDeleteReq.isIsTableModel()) - .values()), + new ArrayList<>(deleteDatabaseSchemaMap.values()), tDeleteReq.isSetIsGeneratedByPipe() && tDeleteReq.isIsGeneratedByPipe()); } else { return status; From 06e79b157ccd9862f7210e42bf78e1262940abdd Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Thu, 12 Dec 2024 20:45:48 +0800 Subject: [PATCH 39/71] Fix --- .../node/write/RelationalInsertTabletNode.java | 14 +++++++------- .../iotdb/commons/partition/DataPartition.java | 18 ++++++++++-------- 2 files changed, 17 insertions(+), 15 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/plan/node/write/RelationalInsertTabletNode.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/plan/node/write/RelationalInsertTabletNode.java index ed88d5cf191a..703217434535 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/plan/node/write/RelationalInsertTabletNode.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/plan/node/write/RelationalInsertTabletNode.java @@ -184,11 +184,11 @@ protected InsertTabletNode getEmptySplit(int count) { } protected Map> splitByReplicaSet( - Map deviceIDSplitInfoMap, IAnalysis analysis) { - Map> splitMap = new HashMap<>(); - Map endPointMap = new HashMap<>(); + final Map deviceIDSplitInfoMap, final IAnalysis analysis) { + final Map> splitMap = new HashMap<>(); + final Map endPointMap = new HashMap<>(); - for (Map.Entry entry : deviceIDSplitInfoMap.entrySet()) { + for (final Map.Entry entry : deviceIDSplitInfoMap.entrySet()) { final IDeviceID deviceID = entry.getKey(); final PartitionSplitInfo splitInfo = entry.getValue(); final List replicaSets = @@ -206,15 +206,15 @@ protected Map> splitByReplicaSet( .get(0) .getClientRpcEndPoint()); for (int i = 0; i < replicaSets.size(); i++) { - List subRanges = + final List subRanges = splitMap.computeIfAbsent(replicaSets.get(i), x -> new ArrayList<>()); subRanges.add(splitInfo.ranges.get(2 * i)); subRanges.add(splitInfo.ranges.get(2 * i + 1)); } } - List redirectNodeList = new ArrayList<>(times.length); + final List redirectNodeList = new ArrayList<>(times.length); for (int i = 0; i < times.length; i++) { - IDeviceID deviceId = getDeviceID(i); + final IDeviceID deviceId = getDeviceID(i); redirectNodeList.add(endPointMap.get(deviceId)); } analysis.setRedirectNodeList(redirectNodeList); diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java index a8470c7005d5..347a8363a928 100644 --- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java +++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/partition/DataPartition.java @@ -203,23 +203,25 @@ public List getDataRegionReplicaSet( } public List getDataRegionReplicaSetForWriting( - IDeviceID deviceID, List timePartitionSlotList, String databaseName) { + final IDeviceID deviceID, + final List timePartitionSlotList, + String databaseName) { if (databaseName == null) { databaseName = getDatabaseNameByDevice(deviceID); } // A list of data region replica sets will store data in a same time partition. // We will insert data to the last set in the list. // TODO return the latest dataRegionReplicaSet for each time partition - TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); + final TSeriesPartitionSlot seriesPartitionSlot = calculateDeviceGroupId(deviceID); // IMPORTANT TODO: (xingtanzjr) need to handle the situation for write operation that there are // more than 1 Regions for one timeSlot - List dataRegionReplicaSets = new ArrayList<>(); - Map>> - dataBasePartitionMap = dataPartitionMap.get(PathUtils.qualifyDatabaseName(databaseName)); - Map> slotReplicaSetMap = + final List dataRegionReplicaSets = new ArrayList<>(); + final Map>> + dataBasePartitionMap = dataPartitionMap.get(databaseName); + final Map> slotReplicaSetMap = dataBasePartitionMap.get(seriesPartitionSlot); - for (TTimePartitionSlot timePartitionSlot : timePartitionSlotList) { - List targetRegionList = slotReplicaSetMap.get(timePartitionSlot); + for (final TTimePartitionSlot timePartitionSlot : timePartitionSlotList) { + final List targetRegionList = slotReplicaSetMap.get(timePartitionSlot); if (targetRegionList == null || targetRegionList.isEmpty()) { throw new RuntimeException( String.format( From c672f0ef55ee7d6c28f303eba8dc1d7882c7d025 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 10:51:48 +0800 Subject: [PATCH 40/71] Test fix --- .../db/tools/schema/SRStatementGenerator.java | 3 +- .../relational/analyzer/AnalyzerTest.java | 4 +- .../utils/SchemaRegionSnapshotParserTest.java | 80 +++++++++---------- 3 files changed, 44 insertions(+), 43 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/tools/schema/SRStatementGenerator.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/tools/schema/SRStatementGenerator.java index 471cf1853fd6..934395655756 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/tools/schema/SRStatementGenerator.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/tools/schema/SRStatementGenerator.java @@ -102,7 +102,8 @@ public class SRStatementGenerator implements Iterator, Iterable fragments = distributedQueryPlan.getFragments(); + final List fragments = distributedQueryPlan.getFragments(); identitySinkNode = (IdentitySinkNode) fragments.get(0).getPlanNodeTree(); assertTrue(getChildrenNode(identitySinkNode, 3) instanceof LimitNode); assertTrue(getChildrenNode(identitySinkNode, 4) instanceof DeviceTableScanNode); diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java index 3da5effd5b3e..92129f9a225a 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/utils/SchemaRegionSnapshotParserTest.java @@ -489,42 +489,42 @@ public void testComplicatedSnapshotParser() throws Exception { // ---------------------------------------------------------------------- // Schema Tree // ---------------------------------------------------------------------- - // This test will construct a complicated mtree. This tree will have - // aligned timeseries, tags and attributes, normal timeseries device template. + // This test will construct a complicated mTree. This tree will have + // aligned timeSeries, tags and attributes, normal timeSeries device template. // // // - // status(BOOLEAN, RLE) alias(stat) - // / - // t2------temperature(INT64, TS_2DIFF,LZ4) - // / - // sg1------s1------t1(activate template: t1) - // / - // root ->| - // \ - // sg2-------t1(aligned)------status(INT64, TS_2DIFF, LZMA2){attr1:atr1} - // \ - // t2-------level{tags:"tag1"="t1", attributes: "attri1"="attr1"} + // status(BOOLEAN, RLE) alias(stat) + // / + // t2------temperature(INT64, TS_2DIFF,LZ4) + // / + // sg1------s1------t1(activate template: t1) + // / + // root -> db ->| // \ - // t1(aligned)-------temperature(INT32, TS_2DIFF, LZ4){attributes:"attr1"="a1"} - // \ - // level(INT32m RLE){tags:"tag1"="t1"} alias(lev) + // sg2-------t1(aligned)------status(INT64, TS_2DIFF, LZMA2){attr1:atr1} + // \ + // t2-------level{tags:"tag1"="t1", attributes: "attri1"="attr1"} + // \ + // t1(aligned)-------temperature(INT32, TS_2DIFF, LZ4){attributes:"attr1"="a1"} + // \ + // level(INT32m RLE){tags:"tag1"="t1"} alias(lev) // // - ISchemaRegion schemaRegion = getSchemaRegion("root", 0); - PartialPath databasePath = new PartialPath("root"); - Template template = new Template(); + final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final PartialPath databasePath = new PartialPath("root.db"); + final Template template = new Template(); template.setId(1); template.addMeasurement("date", TSDataType.INT64, TSEncoding.RLE, CompressionType.UNCOMPRESSED); - HashMap planMap = new HashMap<>(); + final HashMap planMap = new HashMap<>(); planMap.put( - "root.sg1.s1.t1", + "root.db.sg1.s1.t1", SchemaRegionWritePlanFactory.getActivateTemplateInClusterPlan( - new PartialPath("root.sg1.s1.t1"), 3, 1)); + new PartialPath("root.db.sg1.s1.t1"), 3, 1)); planMap.put( - "root.sg1.s1.t2.temperature", + "root.db.sg1.s1.t2.temperature", SchemaRegionWritePlanFactory.getCreateTimeSeriesPlan( - new MeasurementPath("root.sg1.s1.t2.temperature"), + new MeasurementPath("root.db.sg1.s1.t2.temperature"), TSDataType.INT64, TSEncoding.TS_2DIFF, CompressionType.LZ4, @@ -533,9 +533,9 @@ public void testComplicatedSnapshotParser() throws Exception { null, null)); planMap.put( - "root.sg1.s1.t2.status", + "root.db.sg1.s1.t2.status", SchemaRegionWritePlanFactory.getCreateTimeSeriesPlan( - new MeasurementPath("root.sg1.s1.t2.status"), + new MeasurementPath("root.db.sg1.s1.t2.status"), TSDataType.BOOLEAN, TSEncoding.RLE, CompressionType.SNAPPY, @@ -544,9 +544,9 @@ public void testComplicatedSnapshotParser() throws Exception { null, "statusA")); planMap.put( - "root.sg2.t1", + "root.db.sg2.t1", SchemaRegionWritePlanFactory.getCreateAlignedTimeSeriesPlan( - new PartialPath("root.sg2.t1"), + new PartialPath("root.db.sg2.t1"), new ArrayList() { { add("status"); @@ -588,9 +588,9 @@ public void testComplicatedSnapshotParser() throws Exception { } })); planMap.put( - "root.sg2.t2.level", + "root.db.sg2.t2.level", SchemaRegionWritePlanFactory.getCreateTimeSeriesPlan( - new MeasurementPath("root.sg2.t2.level"), + new MeasurementPath("root.db.sg2.t2.level"), TSDataType.INT64, TSEncoding.RLE, CompressionType.UNCOMPRESSED, @@ -607,9 +607,9 @@ public void testComplicatedSnapshotParser() throws Exception { }, null)); planMap.put( - "root.sg2.t2.t1", + "root.db.sg2.t2.t1", SchemaRegionWritePlanFactory.getCreateAlignedTimeSeriesPlan( - new PartialPath("root.sg2.t2.t1"), + new PartialPath("root.db.sg2.t2.t1"), new ArrayList() { { add("temperature"); @@ -662,7 +662,7 @@ public void testComplicatedSnapshotParser() throws Exception { add(new HashMap<>()); } })); - for (ISchemaRegionPlan plan : planMap.values()) { + for (final ISchemaRegionPlan plan : planMap.values()) { if (plan instanceof ICreateTimeSeriesPlan) { schemaRegion.createTimeSeries((ICreateTimeSeriesPlan) plan, -1); } else if (plan instanceof ICreateAlignedTimeSeriesPlan) { @@ -672,11 +672,11 @@ public void testComplicatedSnapshotParser() throws Exception { } } - File snapshotDir = new File(config.getSchemaDir() + File.separator + "snapshot"); + final File snapshotDir = new File(config.getSchemaDir() + File.separator + "snapshot"); snapshotDir.mkdir(); schemaRegion.createSnapshot(snapshotDir); - SRStatementGenerator statements = + final SRStatementGenerator statements = SchemaRegionSnapshotParser.translate2Statements( Paths.get( config.getSchemaDir() @@ -693,10 +693,10 @@ public void testComplicatedSnapshotParser() throws Exception { databasePath); assert statements != null; int count = 0; - Comparator comparator = + final Comparator comparator = new Comparator() { @Override - public int compare(String o1, String o2) { + public int compare(final String o1, final String o2) { if (o1 == null && o2 == null) { return 0; } else if (o1 == null) { @@ -708,11 +708,11 @@ public int compare(String o1, String o2) { } } }; - for (Statement stmt : statements) { + for (final Statement stmt : statements) { if (stmt instanceof CreateAlignedTimeSeriesStatement) { - CreateAlignedTimeSeriesStatement createAlignedTimeSeriesStatement = + final CreateAlignedTimeSeriesStatement createAlignedTimeSeriesStatement = (CreateAlignedTimeSeriesStatement) stmt; - ICreateAlignedTimeSeriesPlan plan = + final ICreateAlignedTimeSeriesPlan plan = (ICreateAlignedTimeSeriesPlan) planMap.get(createAlignedTimeSeriesStatement.getDevicePath().toString()); Assert.assertNotNull(plan); From 56b45363dd86318ff4fd6f490ee7b638455e7edf Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 11:28:47 +0800 Subject: [PATCH 41/71] Fix --- .../manager/schema/ClusterSchemaManager.java | 14 ++------ .../persistence/schema/ConfigMTree.java | 2 +- .../schema/table/DeleteDevicesProcedure.java | 4 +-- .../TableDistributedPlanGenerator.java | 33 ++++++++++--------- .../schemaRegion/SchemaRegionTestUtil.java | 3 +- 5 files changed, 23 insertions(+), 33 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 7dd0ea79b396..4ec74740e05f 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -114,8 +114,6 @@ import java.util.concurrent.locks.ReentrantLock; import java.util.stream.Collectors; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; - /** The ClusterSchemaManager Manages cluster schemaengine read and write requests. */ public class ClusterSchemaManager { @@ -1176,9 +1174,7 @@ public synchronized Pair tableColumnCheckForColumnExtension( return new Pair<>( RpcUtils.getStatus( TSStatusCode.TABLE_NOT_EXISTS, - String.format( - "Table '%s.%s' does not exist", - database.substring(ROOT.length() + 1), tableName)), + String.format("Table '%s.%s' does not exist", database, tableName)), null); } @@ -1214,9 +1210,7 @@ public synchronized Pair tableColumnCheckForColumnRenaming( return new Pair<>( RpcUtils.getStatus( TSStatusCode.TABLE_NOT_EXISTS, - String.format( - "Table '%s.%s' does not exist", - database.substring(ROOT.length() + 1), tableName)), + String.format("Table '%s.%s' does not exist", database, tableName)), null); } @@ -1308,9 +1302,7 @@ public synchronized Pair updateTableProperties( return new Pair<>( RpcUtils.getStatus( TSStatusCode.TABLE_NOT_EXISTS, - String.format( - "Table '%s.%s' does not exist", - database.substring(ROOT.length() + 1), tableName)), + String.format("Table '%s.%s' does not exist", database, tableName)), null); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java index 3300463c71a1..5cce781908a3 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ConfigMTree.java @@ -764,7 +764,7 @@ public Map> getAllUsingTables() { public Map> getAllPreCreateTables() throws MetadataException { final Map> result = new HashMap<>(); final List databaseList = getAllDatabasePaths(true); - for (PartialPath databasePath : databaseList) { + for (final PartialPath databasePath : databaseList) { final String database = databasePath.getFullPath().substring(ROOT.length() + 1); final IConfigMNode databaseNode = getDatabaseNodeByDatabasePath(databasePath).getAsMNode(); for (final IConfigMNode child : databaseNode.getChildren().values()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java index fdb3a12b1d68..6a772ba74938 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java @@ -147,9 +147,7 @@ private void checkTableExistence(final ConfigNodeProcedureEnv env) { setFailure( new ProcedureException( new IoTDBException( - String.format( - "Table '%s.%s' not exists.", - database.substring(ROOT.length() + 1), tableName), + String.format("Table '%s.%s' not exists.", database, tableName), TABLE_NOT_EXISTS.getStatusCode()))); } else { setNextState(CONSTRUCT_BLACK_LIST); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java index 8e3cc11f166c..c72f2d62e596 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java @@ -111,22 +111,22 @@ public class TableDistributedPlanGenerator private final DataNodeLocationSupplierFactory.DataNodeLocationSupplier dataNodeLocationSupplier; public TableDistributedPlanGenerator( - MPPQueryContext queryContext, - Analysis analysis, - SymbolAllocator symbolAllocator, - DataNodeLocationSupplierFactory.DataNodeLocationSupplier dataNodeLocationSupplier) { + final MPPQueryContext queryContext, + final Analysis analysis, + final SymbolAllocator symbolAllocator, + final DataNodeLocationSupplierFactory.DataNodeLocationSupplier dataNodeLocationSupplier) { this.queryId = queryContext.getQueryId(); this.analysis = analysis; this.symbolAllocator = symbolAllocator; this.dataNodeLocationSupplier = dataNodeLocationSupplier; } - public List genResult(PlanNode node, PlanContext context) { - List res = node.accept(this, context); + public List genResult(final PlanNode node, final PlanContext context) { + final List res = node.accept(this, context); if (res.size() == 1) { return res; } else if (res.size() > 1) { - CollectNode collectNode = + final CollectNode collectNode = new CollectNode(queryId.genPlanNodeId(), res.get(0).getOutputSymbols()); res.forEach(collectNode::addChild); return Collections.singletonList(collectNode); @@ -137,34 +137,35 @@ public List genResult(PlanNode node, PlanContext context) { @Override public List visitPlan( - PlanNode node, TableDistributedPlanGenerator.PlanContext context) { + final PlanNode node, final TableDistributedPlanGenerator.PlanContext context) { if (node instanceof WritePlanNode) { return Collections.singletonList(node); } - List> children = + final List> children = node.getChildren().stream() .map(child -> child.accept(this, context)) .collect(toImmutableList()); - PlanNode newNode = node.clone(); - for (List planNodes : children) { + final PlanNode newNode = node.clone(); + for (final List planNodes : children) { planNodes.forEach(newNode::addChild); } return Collections.singletonList(newNode); } @Override - public List visitExplainAnalyze(ExplainAnalyzeNode node, PlanContext context) { - List children = genResult(node.getChild(), context); + public List visitExplainAnalyze( + final ExplainAnalyzeNode node, final PlanContext context) { + final List children = genResult(node.getChild(), context); node.setChild(children.get(0)); return Collections.singletonList(node); } @Override - public List visitOutput(OutputNode node, PlanContext context) { - List childrenNodes = node.getChild().accept(this, context); - OrderingScheme childOrdering = nodeOrderingMap.get(childrenNodes.get(0).getPlanNodeId()); + public List visitOutput(final OutputNode node, final PlanContext context) { + final List childrenNodes = node.getChild().accept(this, context); + final OrderingScheme childOrdering = nodeOrderingMap.get(childrenNodes.get(0).getPlanNodeId()); if (childOrdering != null) { nodeOrderingMap.put(node.getPlanNodeId(), childOrdering); } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTestUtil.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTestUtil.java index 5a700d74d773..1c5c40207d5d 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTestUtil.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTestUtil.java @@ -57,7 +57,6 @@ import static org.apache.iotdb.commons.conf.IoTDBConstant.ONE_LEVEL_PATH_WILDCARD; import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_MATCH_SCOPE; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; public class SchemaRegionTestUtil { @@ -455,7 +454,7 @@ public static List getTableDevice( final List idDeterminedFilterList) { final List patternList = DeviceFilterUtil.convertToDevicePattern( - schemaRegion.getDatabaseFullPath().substring(ROOT.length() + 1), + schemaRegion.getDatabaseFullPath(), table, idColumnNum, Collections.singletonList(idDeterminedFilterList)); From 7527ba14ccea4a16ed197400bec07409397fae12 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 12:02:45 +0800 Subject: [PATCH 42/71] Fix --- .../db/queryengine/plan/analyze/Analysis.java | 27 ++++---- .../queryengine/plan/analyze/IAnalysis.java | 2 +- .../WriteFragmentParallelPlanner.java | 2 +- .../plan/relational/analyzer/Analysis.java | 14 ++--- .../TableDistributedPlanGenerator.java | 30 ++++----- .../PushPredicateIntoTableScan.java | 8 ++- .../analyzer/MockTableModelDataPartition.java | 17 ++--- .../relational/analyzer/TestMatadata.java | 63 +++++++++++-------- 8 files changed, 89 insertions(+), 74 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/Analysis.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/Analysis.java index 1f8905cc666f..770b20ebcf50 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/Analysis.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/Analysis.java @@ -436,12 +436,12 @@ public Expression getGlobalTimePredicate() { return globalTimePredicate; } - public void setGlobalTimePredicate(Expression timeFilter) { + public void setGlobalTimePredicate(final Expression timeFilter) { this.globalTimePredicate = timeFilter; } @Override - public TimePredicate getCovertedTimePredicate() { + public TimePredicate getConvertedTimePredicate() { return globalTimePredicate == null ? null : new TreeModelTimePredicate(globalTimePredicate); } @@ -450,11 +450,11 @@ public DatasetHeader getRespDatasetHeader() { return respDatasetHeader; } - public void setRespDatasetHeader(DatasetHeader respDatasetHeader) { + public void setRespDatasetHeader(final DatasetHeader respDatasetHeader) { this.respDatasetHeader = respDatasetHeader; } - public TSDataType getType(Expression expression) { + public TSDataType getType(final Expression expression) { // NULL_Operand needn't check if (expression.getExpressionType().equals(ExpressionType.NULL)) { return null; @@ -466,13 +466,13 @@ public TSDataType getType(Expression expression) { return deviceTemplate.getSchemaMap().get(seriesOperand.getPath().getMeasurement()).getType(); } - TSDataType type = expressionTypes.get(NodeRef.of(expression)); + final TSDataType type = expressionTypes.get(NodeRef.of(expression)); checkArgument(type != null, "Expression is not analyzed: %s", expression); return type; } @Override - public boolean canSkipExecute(MPPQueryContext context) { + public boolean canSkipExecute(final MPPQueryContext context) { return isFinishQueryAfterAnalyze() || (context.getQueryType() == QueryType.READ && !hasDataSource()); } @@ -486,8 +486,8 @@ private boolean hasDataSource() { } @Override - public TsBlock constructResultForMemorySource(MPPQueryContext context) { - StatementMemorySource memorySource = + public TsBlock constructResultForMemorySource(final MPPQueryContext context) { + final StatementMemorySource memorySource = new StatementMemorySourceVisitor() .process(getTreeStatement(), new StatementMemorySourceContext(context, this)); setRespDatasetHeader(memorySource.getDatasetHeader()); @@ -515,7 +515,8 @@ public Map> getCrossGroupByExpressions() { return crossGroupByExpressions; } - public void setCrossGroupByExpressions(Map> crossGroupByExpressions) { + public void setCrossGroupByExpressions( + final Map> crossGroupByExpressions) { this.crossGroupByExpressions = crossGroupByExpressions; } @@ -523,7 +524,7 @@ public FillDescriptor getFillDescriptor() { return fillDescriptor; } - public void setFillDescriptor(FillDescriptor fillDescriptor) { + public void setFillDescriptor(final FillDescriptor fillDescriptor) { this.fillDescriptor = fillDescriptor; } @@ -531,7 +532,7 @@ public boolean hasValueFilter() { return hasValueFilter; } - public void setHasValueFilter(boolean hasValueFilter) { + public void setHasValueFilter(final boolean hasValueFilter) { this.hasValueFilter = hasValueFilter; } @@ -539,7 +540,7 @@ public Expression getWhereExpression() { return whereExpression; } - public void setWhereExpression(Expression whereExpression) { + public void setWhereExpression(final Expression whereExpression) { this.whereExpression = whereExpression; } @@ -547,7 +548,7 @@ public Map getDeviceToWhereExpression() { return deviceToWhereExpression; } - public void setDeviceToWhereExpression(Map deviceToWhereExpression) { + public void setDeviceToWhereExpression(final Map deviceToWhereExpression) { this.deviceToWhereExpression = deviceToWhereExpression; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IAnalysis.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IAnalysis.java index e03f75db230f..4f48961691d7 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IAnalysis.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IAnalysis.java @@ -72,7 +72,7 @@ default void setRealStatement(Statement realStatement) {} void addEndPointToRedirectNodeList(TEndPoint endPoint); - TimePredicate getCovertedTimePredicate(); + TimePredicate getConvertedTimePredicate(); void setDatabaseName(String databaseName); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/WriteFragmentParallelPlanner.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/WriteFragmentParallelPlanner.java index d43b18c3241f..53c4d3210d2f 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/WriteFragmentParallelPlanner.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/WriteFragmentParallelPlanner.java @@ -74,7 +74,7 @@ public List parallelPlan() { new FragmentInstance( new PlanFragment(fragment.getId(), split), fragment.getId().genFragmentInstanceId(), - analysis.getCovertedTimePredicate(), + analysis.getConvertedTimePredicate(), queryContext.getQueryType(), queryContext.getTimeOut(), queryContext.getSession()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java index e04e94734551..e4479213bf9c 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java @@ -750,7 +750,7 @@ public boolean isFinishQueryAfterAnalyze() { } @Override - public void setDataPartitionInfo(DataPartition dataPartition) { + public void setDataPartitionInfo(final DataPartition dataPartition) { this.dataPartition = dataPartition; } @@ -808,11 +808,11 @@ public DataPartition getDataPartitionInfo() { return dataPartition; } - public void setDataPartition(DataPartition dataPartition) { + public void setDataPartition(final DataPartition dataPartition) { this.dataPartition = dataPartition; } - public void upsertDataPartition(DataPartition targetDataPartition) { + public void upsertDataPartition(final DataPartition targetDataPartition) { if (this.dataPartition == null) { this.dataPartition = targetDataPartition; } else { @@ -826,12 +826,12 @@ public List getRedirectNodeList() { } @Override - public void setRedirectNodeList(List redirectNodeList) { + public void setRedirectNodeList(final List redirectNodeList) { this.redirectNodeList = redirectNodeList; } @Override - public void addEndPointToRedirectNodeList(TEndPoint endPoint) { + public void addEndPointToRedirectNodeList(final TEndPoint endPoint) { if (redirectNodeList == null) { redirectNodeList = new ArrayList<>(); } @@ -839,7 +839,7 @@ public void addEndPointToRedirectNodeList(TEndPoint endPoint) { } public List getDataRegionReplicaSetWithTimeFilter( - String database, IDeviceID deviceId, Filter timeFilter) { + final String database, final IDeviceID deviceId, final Filter timeFilter) { if (dataPartition == null) { return Collections.singletonList(NOT_ASSIGNED); } else { @@ -848,7 +848,7 @@ public List getDataRegionReplicaSetWithTimeFilter( } @Override - public TimePredicate getCovertedTimePredicate() { + public TimePredicate getConvertedTimePredicate() { return null; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java index c72f2d62e596..dbab02fcf2c6 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/distribute/TableDistributedPlanGenerator.java @@ -457,18 +457,19 @@ public List visitJoin(JoinNode node, PlanContext context) { } @Override - public List visitDeviceTableScan(DeviceTableScanNode node, PlanContext context) { - Map tableScanNodeMap = new HashMap<>(); + public List visitDeviceTableScan( + final DeviceTableScanNode node, final PlanContext context) { + final Map tableScanNodeMap = new HashMap<>(); - for (DeviceEntry deviceEntry : node.getDeviceEntries()) { - List regionReplicaSets = + for (final DeviceEntry deviceEntry : node.getDeviceEntries()) { + final List regionReplicaSets = analysis.getDataRegionReplicaSetWithTimeFilter( node.getQualifiedObjectName().getDatabaseName(), deviceEntry.getDeviceID(), node.getTimeFilter()); - for (TRegionReplicaSet regionReplicaSet : regionReplicaSets) { - DeviceTableScanNode deviceTableScanNode = + for (final TRegionReplicaSet regionReplicaSet : regionReplicaSets) { + final DeviceTableScanNode deviceTableScanNode = tableScanNodeMap.computeIfAbsent( regionReplicaSet, k -> { @@ -498,12 +499,13 @@ public List visitDeviceTableScan(DeviceTableScanNode node, PlanContext return Collections.singletonList(node); } - List resultTableScanNodeList = new ArrayList<>(); + final List resultTableScanNodeList = new ArrayList<>(); TRegionReplicaSet mostUsedDataRegion = null; int maxDeviceEntrySizeOfTableScan = 0; - for (Map.Entry entry : tableScanNodeMap.entrySet()) { - TRegionReplicaSet regionReplicaSet = entry.getKey(); - DeviceTableScanNode subDeviceTableScanNode = entry.getValue(); + for (final Map.Entry entry : + tableScanNodeMap.entrySet()) { + final TRegionReplicaSet regionReplicaSet = entry.getKey(); + final DeviceTableScanNode subDeviceTableScanNode = entry.getValue(); subDeviceTableScanNode.setPlanNodeId(queryId.genPlanNodeId()); subDeviceTableScanNode.setRegionReplicaSet(regionReplicaSet); resultTableScanNodeList.add(subDeviceTableScanNode); @@ -741,18 +743,18 @@ private static OrderingScheme constructOrderingSchema(List symbols) { } private PlanNode mergeChildrenViaCollectOrMergeSort( - OrderingScheme childOrdering, List childrenNodes) { + final OrderingScheme childOrdering, final List childrenNodes) { checkArgument(!childrenNodes.isEmpty(), "childrenNodes should not be empty"); if (childrenNodes.size() == 1) { return childrenNodes.get(0); } - PlanNode firstChild = childrenNodes.get(0); + final PlanNode firstChild = childrenNodes.get(0); // children has sort property, use MergeSort to merge children if (childOrdering != null) { - MergeSortNode mergeSortNode = + final MergeSortNode mergeSortNode = new MergeSortNode(queryId.genPlanNodeId(), childOrdering, firstChild.getOutputSymbols()); childrenNodes.forEach(mergeSortNode::addChild); nodeOrderingMap.put(mergeSortNode.getPlanNodeId(), childOrdering); @@ -760,7 +762,7 @@ private PlanNode mergeChildrenViaCollectOrMergeSort( } // children has no sort property, use CollectNode to merge children - CollectNode collectNode = + final CollectNode collectNode = new CollectNode(queryId.genPlanNodeId(), firstChild.getOutputSymbols()); childrenNodes.forEach(collectNode::addChild); return collectNode; diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java index 72f3ade0c69e..754414a22745 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/planner/optimizations/PushPredicateIntoTableScan.java @@ -753,8 +753,10 @@ public PlanNode visitRelationalInsertTablet( } private DataPartition fetchDataPartitionByDevices( - String database, List deviceEntries, Filter globalTimeFilter) { - Pair, Pair> res = + final String database, + final List deviceEntries, + final Filter globalTimeFilter) { + final Pair, Pair> res = getTimePartitionSlotList(globalTimeFilter, queryContext); // there is no satisfied time range @@ -765,7 +767,7 @@ private DataPartition fetchDataPartitionByDevices( CONFIG.getSeriesPartitionSlotNum()); } - List dataPartitionQueryParams = + final List dataPartitionQueryParams = deviceEntries.stream() .map( deviceEntry -> diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/MockTableModelDataPartition.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/MockTableModelDataPartition.java index db6e1addeb0a..c536d21f17df 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/MockTableModelDataPartition.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/MockTableModelDataPartition.java @@ -48,7 +48,7 @@ public class MockTableModelDataPartition { IoTDBDescriptor.getInstance().getConfig().getSeriesPartitionExecutorClass(), IoTDBDescriptor.getInstance().getConfig().getSeriesPartitionSlotNum()); - private static final String DB_NAME = "root.testdb"; + private static final String DB_NAME = "testdb"; static final String DEVICE_1 = "table1.beijing.A1.ZZ"; static final String DEVICE_2 = "table1.beijing.A2.XX"; @@ -139,25 +139,26 @@ public static DataPartition constructDataPartition() { } public static SchemaPartition constructSchemaPartition() { - SchemaPartition schemaPartition = + final SchemaPartition schemaPartition = new SchemaPartition( IoTDBDescriptor.getInstance().getConfig().getSeriesPartitionExecutorClass(), IoTDBDescriptor.getInstance().getConfig().getSeriesPartitionSlotNum()); - Map> schemaPartitionMap = new HashMap<>(); + final Map> schemaPartitionMap = + new HashMap<>(); - TRegionReplicaSet schemaRegion1 = + final TRegionReplicaSet schemaRegion1 = new TRegionReplicaSet( new TConsensusGroupId(TConsensusGroupType.SchemaRegion, 11), Arrays.asList( genDataNodeLocation(11, "192.0.1.1"), genDataNodeLocation(12, "192.0.1.2"))); - TRegionReplicaSet schemaRegion2 = + final TRegionReplicaSet schemaRegion2 = new TRegionReplicaSet( new TConsensusGroupId(TConsensusGroupType.SchemaRegion, 21), Arrays.asList( genDataNodeLocation(21, "192.0.2.1"), genDataNodeLocation(22, "192.0.2.2"))); - Map schemaRegionMap = new HashMap<>(); + final Map schemaRegionMap = new HashMap<>(); schemaRegionMap.put(EXECUTOR.getSeriesPartitionSlot(DEVICE_1), schemaRegion1); schemaRegionMap.put(EXECUTOR.getSeriesPartitionSlot(DEVICE_2), schemaRegion2); schemaRegionMap.put(EXECUTOR.getSeriesPartitionSlot(DEVICE_3), schemaRegion2); @@ -168,7 +169,7 @@ public static SchemaPartition constructSchemaPartition() { } private static TRegionReplicaSet genDataRegionGroup( - int regionGroupId, int dataNodeId1, int dataNodeId2) { + final int regionGroupId, final int dataNodeId1, final int dataNodeId2) { return new TRegionReplicaSet( new TConsensusGroupId(TConsensusGroupType.DataRegion, regionGroupId), Arrays.asList( @@ -176,7 +177,7 @@ private static TRegionReplicaSet genDataRegionGroup( genDataNodeLocation(dataNodeId2, String.format("192.0.%s.2", regionGroupId)))); } - public static TDataNodeLocation genDataNodeLocation(int dataNodeId, String ip) { + public static TDataNodeLocation genDataNodeLocation(final int dataNodeId, final String ip) { return new TDataNodeLocation() .setDataNodeId(dataNodeId) .setClientRpcEndPoint(new TEndPoint(ip, 9000)) diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java index 49a20589efa0..af1bd741fd67 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java @@ -116,19 +116,20 @@ public class TestMatadata implements Metadata { public static final String TABLE2 = "table2"; @Override - public boolean tableExists(QualifiedObjectName name) { + public boolean tableExists(final QualifiedObjectName name) { return name.getDatabaseName().equalsIgnoreCase(DB1) && name.getObjectName().equalsIgnoreCase(TABLE1); } @Override - public Optional getTableSchema(SessionInfo session, QualifiedObjectName name) { + public Optional getTableSchema( + final SessionInfo session, final QualifiedObjectName name) { if (name.getDatabaseName().equals(INFORMATION_SCHEMA)) { - TsTable table = InformationSchemaTable.getTableFromStringValue(name.getObjectName()); + final TsTable table = InformationSchemaTable.getTableFromStringValue(name.getObjectName()); if (table == null) { return Optional.empty(); } - List columnSchemaList = + final List columnSchemaList = table.getColumnList().stream() .map( o -> @@ -141,7 +142,7 @@ public Optional getTableSchema(SessionInfo session, QualifiedObject return Optional.of(new TableSchema(table.getTableName(), columnSchemaList)); } - List columnSchemas = + final List columnSchemas = Arrays.asList( ColumnSchema.builder(TIME_CM).setColumnCategory(TsTableColumnCategory.TIME).build(), ColumnSchema.builder(TAG1_CM).setColumnCategory(TsTableColumnCategory.ID).build(), @@ -167,7 +168,8 @@ public Optional getTableSchema(SessionInfo session, QualifiedObject } @Override - public Type getOperatorReturnType(OperatorType operatorType, List argumentTypes) + public Type getOperatorReturnType( + final OperatorType operatorType, final List argumentTypes) throws OperatorNotFoundException { switch (operatorType) { @@ -208,24 +210,25 @@ public Type getOperatorReturnType(OperatorType operatorType, List argumentTypes) { + public Type getFunctionReturnType( + final String functionName, final List argumentTypes) { return getFunctionType(functionName, argumentTypes); } @Override public boolean isAggregationFunction( - SessionInfo session, String functionName, AccessControl accessControl) { + final SessionInfo session, final String functionName, final AccessControl accessControl) { return BuiltinAggregationFunction.getNativeFunctionNames() .contains(functionName.toLowerCase(Locale.ENGLISH)); } @Override - public Type getType(TypeSignature signature) throws TypeNotFoundException { + public Type getType(final TypeSignature signature) throws TypeNotFoundException { return typeManager.getType(signature); } @Override - public boolean canCoerce(Type from, Type to) { + public boolean canCoerce(final Type from, final Type to) { return true; } @@ -236,10 +239,10 @@ public IPartitionFetcher getPartitionFetcher() { @Override public List indexScan( - QualifiedObjectName tableName, - List expressionList, - List attributeColumns, - MPPQueryContext context) { + final QualifiedObjectName tableName, + final List expressionList, + final List attributeColumns, + final MPPQueryContext context) { if (expressionList.size() == 2) { if (compareEqualsMatch(expressionList.get(0), "tag1", "beijing") @@ -290,12 +293,13 @@ && compareEqualsMatch(expressionList.get(0), "tag2", "B3")) { new DeviceEntry(new StringArrayDeviceID(DEVICE_2.split("\\.")), DEVICE_2_ATTRIBUTES)); } - private boolean compareEqualsMatch(Expression expression, String idOrAttr, String value) { + private boolean compareEqualsMatch( + final Expression expression, final String idOrAttr, final String value) { if (expression instanceof ComparisonExpression && ((ComparisonExpression) expression).getOperator() == ComparisonExpression.Operator.EQUAL) { - Expression leftExpression = ((ComparisonExpression) expression).getLeft(); - Expression rightExpression = ((ComparisonExpression) expression).getRight(); + final Expression leftExpression = ((ComparisonExpression) expression).getLeft(); + final Expression rightExpression = ((ComparisonExpression) expression).getRight(); if (leftExpression instanceof SymbolReference && rightExpression instanceof StringLiteral) { return ((SymbolReference) leftExpression).getName().equalsIgnoreCase(idOrAttr) && ((StringLiteral) rightExpression).getValue().equalsIgnoreCase(value); @@ -309,12 +313,13 @@ private boolean compareEqualsMatch(Expression expression, String idOrAttr, Strin return false; } - private boolean compareNotEqualsMatch(Expression expression, String idOrAttr, String value) { + private boolean compareNotEqualsMatch( + final Expression expression, final String idOrAttr, final String value) { if (expression instanceof ComparisonExpression && ((ComparisonExpression) expression).getOperator() == ComparisonExpression.Operator.NOT_EQUAL) { - Expression leftExpression = ((ComparisonExpression) expression).getLeft(); - Expression rightExpression = ((ComparisonExpression) expression).getRight(); + final Expression leftExpression = ((ComparisonExpression) expression).getLeft(); + final Expression rightExpression = ((ComparisonExpression) expression).getRight(); if (leftExpression instanceof SymbolReference && rightExpression instanceof StringLiteral) { return ((SymbolReference) leftExpression).getName().equalsIgnoreCase(idOrAttr) && ((StringLiteral) rightExpression).getValue().equalsIgnoreCase(value); @@ -330,41 +335,45 @@ private boolean compareNotEqualsMatch(Expression expression, String idOrAttr, St @Override public Optional validateTableHeaderSchema( - String database, TableSchema tableSchema, MPPQueryContext context, boolean allowCreateTable) { + final String database, + final TableSchema tableSchema, + final MPPQueryContext context, + final boolean allowCreateTable) { throw new UnsupportedOperationException(); } @Override public void validateDeviceSchema( - ITableDeviceSchemaValidation schemaValidation, MPPQueryContext context) { + final ITableDeviceSchemaValidation schemaValidation, final MPPQueryContext context) { throw new UnsupportedOperationException(); } @Override public SchemaPartition getOrCreateSchemaPartition( - String database, List deviceIDList, String userName) { + final String database, final List deviceIDList, final String userName) { return null; } @Override - public SchemaPartition getSchemaPartition(String database, List deviceIDList) { + public SchemaPartition getSchemaPartition( + final String database, final List deviceIDList) { return null; } @Override - public SchemaPartition getSchemaPartition(String database) { + public SchemaPartition getSchemaPartition(final String database) { return null; } @Override public DataPartition getDataPartition( - String database, List sgNameToQueryParamsMap) { + final String database, final List sgNameToQueryParamsMap) { return DATA_PARTITION; } @Override public DataPartition getDataPartitionWithUnclosedTimeRange( - String database, List sgNameToQueryParamsMap) { + final String database, final List sgNameToQueryParamsMap) { return DATA_PARTITION; } From 122c0efdcc98541e93ba064f24d25c19b3528df9 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 12:13:33 +0800 Subject: [PATCH 43/71] Update IoTDBDatabaseIT.java --- .../relational/it/schema/IoTDBDatabaseIT.java | 49 +++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java b/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java index bc282384bf7c..493d7487af8a 100644 --- a/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/relational/it/schema/IoTDBDatabaseIT.java @@ -105,6 +105,8 @@ public void testManageDatabase() { assertEquals(databaseNames.length, cnt); } + final int[] schemaRegionGroupNum = new int[] {0}; + final int[] dataRegionGroupNum = new int[] {0}; // show try (final ResultSet resultSet = statement.executeQuery("SHOW DATABASES DETAILS")) { int cnt = 0; @@ -120,6 +122,8 @@ public void testManageDatabase() { assertEquals(schemaReplicaFactors[cnt], resultSet.getInt(3)); assertEquals(dataReplicaFactors[cnt], resultSet.getInt(4)); assertEquals(timePartitionInterval[cnt], resultSet.getLong(5)); + assertEquals(schemaRegionGroupNum[cnt], resultSet.getInt(6)); + assertEquals(dataRegionGroupNum[cnt], resultSet.getInt(7)); cnt++; } assertEquals(databaseNames.length, cnt); @@ -303,4 +307,49 @@ public void testDatabaseWithSpecificCharacters() throws SQLException { Collections.singleton("1,4,")); } } + + @Test + public void testMixedDatabase() throws SQLException { + try (final Connection connection = + EnvFactory.getEnv().getConnection(BaseEnv.TABLE_SQL_DIALECT); + final Statement statement = connection.createStatement()) { + statement.execute("create database test"); + } + + try (final Connection connection = EnvFactory.getEnv().getConnection(); + final Statement statement = connection.createStatement()) { + statement.execute("create database root.test"); + statement.execute( + "alter database root.test WITH SCHEMA_REGION_GROUP_NUM=2, DATA_REGION_GROUP_NUM=3"); + statement.execute("drop database root.test"); + } + + try (final Connection connection = + EnvFactory.getEnv().getConnection(BaseEnv.TABLE_SQL_DIALECT); + final Statement statement = connection.createStatement()) { + try (final ResultSet resultSet = statement.executeQuery("SHOW DATABASES DETAILS")) { + assertTrue(resultSet.next()); + assertEquals("test", resultSet.getString(1)); + assertEquals(0, resultSet.getInt(6)); + assertEquals(0, resultSet.getInt(7)); + assertFalse(resultSet.next()); + } + } + + try (final Connection connection = EnvFactory.getEnv().getConnection(); + final Statement statement = connection.createStatement()) { + statement.execute("create database root.test"); + } + + try (final Connection connection = + EnvFactory.getEnv().getConnection(BaseEnv.TABLE_SQL_DIALECT); + final Statement statement = connection.createStatement()) { + statement.execute("drop database test"); + } + + try (final Connection connection = EnvFactory.getEnv().getConnection(); + final Statement statement = connection.createStatement()) { + TestUtils.assertResultSetSize(statement.executeQuery("show databases"), 1); + } + } } From 19e6dedea99dd5db9946b26ada4b5d9500eb3944 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 14:42:11 +0800 Subject: [PATCH 44/71] Update ClusterSchemaInfo.java --- .../iotdb/confignode/persistence/schema/ClusterSchemaInfo.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 0fff22cf5d4d..7dc671d0189f 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -203,7 +203,8 @@ public TSStatus alterDatabase(final DatabaseSchemaPlan plan) { databaseReadWriteLock.writeLock().lock(); try { final TDatabaseSchema alterSchema = plan.getSchema(); - final PartialPath partialPathName = new PartialPath(alterSchema.getName()); + final PartialPath partialPathName = + PartialPath.getQualifiedDatabasePartialPath(alterSchema.getName()); final ConfigMTree mTree = plan.getSchema().isIsTableModel() ? tableModelMTree : treeModelMTree; From 9504386830866326c3da0f8ad21d7392ff49400b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 14:48:36 +0800 Subject: [PATCH 45/71] Update AnalyzerTest.java --- .../relational/analyzer/AnalyzerTest.java | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java index f703d4179132..773a5b8eed8d 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java @@ -1100,27 +1100,28 @@ public void validateDeviceSchema( @Override public DataPartition getOrCreateDataPartition( - List dataPartitionQueryParams, String userName) { - int seriesSlotNum = StatementTestUtils.TEST_SERIES_SLOT_NUM; - String partitionExecutorName = StatementTestUtils.TEST_PARTITION_EXECUTOR; - SeriesPartitionExecutor seriesPartitionExecutor = + final List dataPartitionQueryParams, final String userName) { + final int seriesSlotNum = StatementTestUtils.TEST_SERIES_SLOT_NUM; + final String partitionExecutorName = StatementTestUtils.TEST_PARTITION_EXECUTOR; + final SeriesPartitionExecutor seriesPartitionExecutor = SeriesPartitionExecutor.getSeriesPartitionExecutor( partitionExecutorName, seriesSlotNum); - Map>>> + final Map< + String, Map>>> dataPartitionMap = new HashMap<>(); - for (DataPartitionQueryParam dataPartitionQueryParam : dataPartitionQueryParams) { + for (final DataPartitionQueryParam dataPartitionQueryParam : dataPartitionQueryParams) { String databaseName = dataPartitionQueryParam.getDatabaseName(); - assertEquals("root." + sessionInfo.getDatabaseName().get(), databaseName); + assertEquals(sessionInfo.getDatabaseName().get(), databaseName); databaseName = PathUtils.qualifyDatabaseName(databaseName); - String tableName = dataPartitionQueryParam.getDeviceID().getTableName(); + final String tableName = dataPartitionQueryParam.getDeviceID().getTableName(); assertEquals(StatementTestUtils.tableName(), tableName); - TSeriesPartitionSlot partitionSlot = + final TSeriesPartitionSlot partitionSlot = seriesPartitionExecutor.getSeriesPartitionSlot(dataPartitionQueryParam.getDeviceID()); - for (TTimePartitionSlot tTimePartitionSlot : + for (final TTimePartitionSlot tTimePartitionSlot : dataPartitionQueryParam.getTimePartitionSlotList()) { dataPartitionMap .computeIfAbsent(databaseName, d -> new HashMap<>()) From 534ea5eaf1469f7258418a01f961b665382dfd12 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 14:50:20 +0800 Subject: [PATCH 46/71] Fixed --- .../schemaRegion/SchemaRegionTableDeviceTest.java | 10 +++++----- .../db/metadata/schemaRegion/SchemaStatisticsTest.java | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTableDeviceTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTableDeviceTest.java index 84307a421175..ef56ea249e4b 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTableDeviceTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionTableDeviceTest.java @@ -52,7 +52,7 @@ public void testDeviceCreation() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName = "t"; final List deviceIdList = Arrays.asList( @@ -133,7 +133,7 @@ public void testDeviceQuery() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName = "t"; final Map attributeMap = new HashMap<>(); @@ -204,7 +204,7 @@ public void testDeviceIdWithNull() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName = "t"; final Map attributeMap = new HashMap<>(); @@ -280,7 +280,7 @@ public void testDeviceWithDifferentIdLength() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName = "t"; final Map attributeMap = new HashMap<>(); @@ -325,7 +325,7 @@ public void testMultiTableDevice() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName1 = "t1"; final Map attributeMap = new HashMap<>(); diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaStatisticsTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaStatisticsTest.java index b0432c15e9ee..61d641f757d9 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaStatisticsTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaStatisticsTest.java @@ -405,7 +405,7 @@ public void testTableDeviceStatistics() throws Exception { if (!testParams.getTestModeName().equals("MemoryMode")) { return; } - final ISchemaRegion schemaRegion = getSchemaRegion("root.db", 0); + final ISchemaRegion schemaRegion = getSchemaRegion("db", 0); final String tableName1 = "t1"; final Map attributeMap = new HashMap<>(); From ee59eaecd45ab0696b0907e48f395bb19982602b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:28:32 +0800 Subject: [PATCH 47/71] Fix --- .../iotdb/confignode/persistence/schema/ClusterSchemaInfo.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 7dc671d0189f..6401a87d9e3a 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -1130,7 +1130,7 @@ public TSStatus commitCreateTable(final CommitCreateTablePlan plan) { public TSStatus preDeleteTable(final PreDeleteTablePlan plan) { databaseReadWriteLock.writeLock().lock(); try { - treeModelMTree.preDeleteTable( + tableModelMTree.preDeleteTable( getQualifiedDatabasePartialPath(plan.getDatabase()), plan.getTableName()); return RpcUtils.SUCCESS_STATUS; } catch (final MetadataException e) { From 3cc064c1a55d13aea1c8ebd31f15bfe58c9de002 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 17:11:35 +0800 Subject: [PATCH 48/71] Fix --- .../procedure/impl/schema/table/DeleteDevicesProcedure.java | 2 +- .../procedure/impl/schema/table/DropTableColumnProcedure.java | 2 +- .../procedure/impl/schema/table/DropTableProcedure.java | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java index 6a772ba74938..cc804dbf7ac2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java @@ -163,7 +163,7 @@ private void constructBlackList(final ConfigNodeProcedureEnv env) { final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); final PartialPath path; try { - path = new PartialPath(new String[] {ROOT, database.substring(5), tableName}); + path = new PartialPath(new String[] {ROOT, database, tableName}); patternTree.appendPathPattern(path); patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); patternTree.serialize(dataOutputStream); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java index aa4568995406..9b8a7dd10927 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java @@ -184,7 +184,7 @@ private void executeOnRegions(final ConfigNodeProcedureEnv env) { final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); final PartialPath path; try { - path = new PartialPath(new String[] {ROOT, database.substring(5), tableName}); + path = new PartialPath(new String[] {ROOT, database, tableName}); patternTree.appendPathPattern(path); patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); patternTree.serialize(dataOutputStream); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java index 4a8acb42cdad..7abfdc63c2d2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java @@ -159,7 +159,7 @@ private void deleteData(final ConfigNodeProcedureEnv env) { final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); final PartialPath path; try { - path = new PartialPath(new String[] {ROOT, database.substring(5), tableName}); + path = new PartialPath(new String[] {ROOT, database, tableName}); patternTree.appendPathPattern(path); patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); patternTree.serialize(dataOutputStream); @@ -192,7 +192,7 @@ private void deleteSchema(final ConfigNodeProcedureEnv env) { final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); final PartialPath path; try { - path = new PartialPath(new String[] {ROOT, database.substring(5), tableName}); + path = new PartialPath(new String[] {ROOT, database, tableName}); patternTree.appendPathPattern(path); patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); patternTree.serialize(dataOutputStream); From 910c0992cbbe2934be70a7d7388b4da3befe2271 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 17:28:16 +0800 Subject: [PATCH 49/71] Fix --- .../plan/analyze/AnalyzeUtils.java | 2 +- .../plan/relational/analyzer/Analysis.java | 40 ++++++++++--------- .../relational/analyzer/AnalyzerTest.java | 24 +++++------ 3 files changed, 34 insertions(+), 32 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java index 52bfcf2222b1..2b60abcfb736 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/AnalyzeUtils.java @@ -574,7 +574,7 @@ private static IDPredicate getIdPredicate( public interface DataPartitionQueryFunc { DataPartition queryDataPartition( - List dataPartitionQueryParams, String userName); + final List dataPartitionQueryParams, final String userName); } public interface DataPartitionQueryParamComputation { diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java index f935aad9cb66..c056c9a3ff9e 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/Analysis.java @@ -642,37 +642,37 @@ public RelationType getOutputDescriptor() { return getOutputDescriptor(root); } - public RelationType getOutputDescriptor(Node node) { + public RelationType getOutputDescriptor(final Node node) { return getScope(node).getRelationType(); } - public void addSourceColumns(Field field, Set sourceColumn) { + public void addSourceColumns(final Field field, final Set sourceColumn) { originColumnDetails.putAll(field, sourceColumn); } - public Set getSourceColumns(Field field) { + public Set getSourceColumns(final Field field) { return ImmutableSet.copyOf(originColumnDetails.get(field)); } - public void addExpressionFields(Expression expression, Collection fields) { + public void addExpressionFields(final Expression expression, final Collection fields) { fieldLineage.putAll(NodeRef.of(expression), fields); } - public Set getExpressionSourceColumns(Expression expression) { + public Set getExpressionSourceColumns(final Expression expression) { return fieldLineage.get(NodeRef.of(expression)).stream() .flatMap(field -> getSourceColumns(field).stream()) .collect(toImmutableSet()); } - public void setRelationName(Relation relation, QualifiedName name) { + public void setRelationName(final Relation relation, final QualifiedName name) { relationNames.put(NodeRef.of(relation), name); } - public QualifiedName getRelationName(Relation relation) { + public QualifiedName getRelationName(final Relation relation) { return relationNames.get(NodeRef.of(relation)); } - public void addAliased(Relation relation) { + public void addAliased(final Relation relation) { aliasedRelations.add(NodeRef.of(relation)); } @@ -681,19 +681,21 @@ public boolean isAliased(Relation relation) { } public void addTableSchema( - QualifiedObjectName qualifiedObjectName, Map tableColumnSchema) { + final QualifiedObjectName qualifiedObjectName, + final Map tableColumnSchema) { tableColumnSchemas.put(qualifiedObjectName, tableColumnSchema); } - public Map getTableColumnSchema(QualifiedObjectName qualifiedObjectName) { + public Map getTableColumnSchema( + final QualifiedObjectName qualifiedObjectName) { return tableColumnSchemas.get(qualifiedObjectName); } - public void addPredicateCoercions(Map, PredicateCoercions> coercions) { + public void addPredicateCoercions(final Map, PredicateCoercions> coercions) { predicateCoercions.putAll(coercions); } - public PredicateCoercions getPredicateCoercions(Expression expression) { + public PredicateCoercions getPredicateCoercions(final Expression expression) { return predicateCoercions.get(NodeRef.of(expression)); } @@ -709,7 +711,7 @@ public boolean hasSortNode() { return hasSortNode; } - public void setSortNode(boolean hasSortNode) { + public void setSortNode(final boolean hasSortNode) { this.hasSortNode = hasSortNode; } @@ -717,7 +719,7 @@ public boolean isEmptyDataSource() { return emptyDataSource; } - public void setEmptyDataSource(boolean emptyDataSource) { + public void setEmptyDataSource(final boolean emptyDataSource) { this.emptyDataSource = emptyDataSource; } @@ -732,12 +734,12 @@ public TSStatus getFailStatus() { } @Override - public void setFailStatus(TSStatus failStatus) { + public void setFailStatus(final TSStatus failStatus) { this.failStatus = failStatus; } @Override - public boolean canSkipExecute(MPPQueryContext context) { + public boolean canSkipExecute(final MPPQueryContext context) { return isFinishQueryAfterAnalyze(); } @@ -746,7 +748,7 @@ public void setFinishQueryAfterAnalyze() { } @Override - public void setFinishQueryAfterAnalyze(boolean finishQueryAfterAnalyze) { + public void setFinishQueryAfterAnalyze(final boolean finishQueryAfterAnalyze) { this.finishQueryAfterAnalyze = finishQueryAfterAnalyze; } @@ -760,9 +762,9 @@ public void setDataPartitionInfo(final DataPartition dataPartition) { } @Override - public TsBlock constructResultForMemorySource(MPPQueryContext context) { + public TsBlock constructResultForMemorySource(final MPPQueryContext context) { requireNonNull(getStatement(), "root statement is analysis is null"); - StatementMemorySource memorySource = + final StatementMemorySource memorySource = new TableModelStatementMemorySourceVisitor() .process(getStatement(), new TableModelStatementMemorySourceContext(context, this)); setRespDatasetHeader(memorySource.getDatasetHeader()); diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java index 773a5b8eed8d..ecab7d2242a4 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/AnalyzerTest.java @@ -29,7 +29,6 @@ import org.apache.iotdb.commons.partition.DataPartition; import org.apache.iotdb.commons.partition.DataPartitionQueryParam; import org.apache.iotdb.commons.partition.executor.SeriesPartitionExecutor; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.protocol.session.IClientSession; import org.apache.iotdb.db.queryengine.common.MPPQueryContext; import org.apache.iotdb.db.queryengine.common.QueryId; @@ -1112,9 +1111,8 @@ public DataPartition getOrCreateDataPartition( dataPartitionMap = new HashMap<>(); for (final DataPartitionQueryParam dataPartitionQueryParam : dataPartitionQueryParams) { - String databaseName = dataPartitionQueryParam.getDatabaseName(); + final String databaseName = dataPartitionQueryParam.getDatabaseName(); assertEquals(sessionInfo.getDatabaseName().get(), databaseName); - databaseName = PathUtils.qualifyDatabaseName(databaseName); final String tableName = dataPartitionQueryParam.getDeviceID().getTableName(); assertEquals(StatementTestUtils.tableName(), tableName); @@ -1159,7 +1157,7 @@ public void analyzeInsertTablet() { analysis .getDataPartition() .getDataPartitionMap() - .get(PathUtils.qualifyDatabaseName(sessionInfo.getDatabaseName().orElse(null))); + .get(sessionInfo.getDatabaseName().orElse(null)); assertEquals(3, partitionSlotMapMap.size()); SymbolAllocator symbolAllocator = new SymbolAllocator(); @@ -1192,9 +1190,9 @@ public void analyzeInsertTablet() { @Test public void analyzeInsertRow() { - Metadata mockMetadata = mockMetadataForInsertion(); + final Metadata mockMetadata = mockMetadataForInsertion(); - InsertRowStatement insertStatement = StatementTestUtils.genInsertRowStatement(true); + final InsertRowStatement insertStatement = StatementTestUtils.genInsertRowStatement(true); context = new MPPQueryContext("", queryId, sessionInfo, null, null); analysis = analyzeStatement( @@ -1204,26 +1202,28 @@ public void analyzeInsertRow() { new SqlParser(), sessionInfo); assertEquals(1, analysis.getDataPartition().getDataPartitionMap().size()); - Map>> + assertEquals(1, analysis.getDataPartition().getDataPartitionMap().size()); + final Map>> partitionSlotMapMap = analysis .getDataPartition() .getDataPartitionMap() - .get(PathUtils.qualifyDatabaseName(sessionInfo.getDatabaseName().orElse(null))); + .get(sessionInfo.getDatabaseName().orElse(null)); assertEquals(1, partitionSlotMapMap.size()); - SymbolAllocator symbolAllocator = new SymbolAllocator(); + final SymbolAllocator symbolAllocator = new SymbolAllocator(); logicalQueryPlan = new TableLogicalPlanner( context, mockMetadata, sessionInfo, symbolAllocator, WarningCollector.NOOP) .plan(analysis); - RelationalInsertRowNode insertNode = (RelationalInsertRowNode) logicalQueryPlan.getRootNode(); + final RelationalInsertRowNode insertNode = + (RelationalInsertRowNode) logicalQueryPlan.getRootNode(); assertEquals(insertNode.getTableName(), StatementTestUtils.tableName()); - Object[] columns = StatementTestUtils.genValues(0); + final Object[] columns = StatementTestUtils.genValues(0); assertEquals( Factory.DEFAULT_FACTORY.create( - new String[] {StatementTestUtils.tableName(), ((Binary) columns[0]).toString()}), + new String[] {StatementTestUtils.tableName(), columns[0].toString()}), insertNode.getDeviceID()); assertArrayEquals(columns, insertNode.getValues()); From 21479696f827093a6aa341bd40b9edeeae234ea9 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 19:16:47 +0800 Subject: [PATCH 50/71] Revert "Delete database" This reverts commit 6cacf0442d16259140614d96ae13385828a82fa1. --- .../consensus/request/ConfigPhysicalPlan.java | 3 --- .../consensus/request/ConfigPhysicalPlanType.java | 1 - .../request/write/database/DeleteDatabasePlan.java | 7 +++---- .../pipe/extractor/ConfigRegionListeningFilter.java | 4 +--- .../receiver/protocol/IoTDBConfigNodeReceiver.java | 5 ----- .../manager/schema/ClusterSchemaManager.java | 3 ++- .../persistence/executor/ConfigPlanExecutor.java | 13 ++----------- .../persistence/partition/PartitionInfo.java | 9 +++++---- .../persistence/schema/ClusterSchemaInfo.java | 9 +++++---- .../procedure/env/ConfigNodeProcedureEnv.java | 10 +++++----- .../impl/schema/DeleteDatabaseProcedure.java | 9 ++------- 11 files changed, 25 insertions(+), 48 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java index acff13b45426..cc1aaee05553 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlan.java @@ -202,9 +202,6 @@ public static ConfigPhysicalPlan create(final ByteBuffer buffer) throws IOExcept case AlterDatabase: plan = new DatabaseSchemaPlan(ConfigPhysicalPlanType.AlterDatabase); break; - case DeleteDatabaseV2: - plan = new DatabaseSchemaPlan(ConfigPhysicalPlanType.DeleteDatabaseV2); - break; case SetTTL: plan = new SetTTLPlan(); break; diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java index f8f727081362..5d3bdcc6710e 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/ConfigPhysicalPlanType.java @@ -55,7 +55,6 @@ public enum ConfigPhysicalPlanType { CountDatabase((short) 209), AlterDatabase((short) 210), ShowTTL((short) 211), - DeleteDatabaseV2((short) 212), /** Region. */ CreateRegionGroups((short) 300), diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java index 29ba660c3086..f026275f9fb4 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/database/DeleteDatabasePlan.java @@ -28,7 +28,6 @@ import java.nio.ByteBuffer; import java.util.Objects; -@Deprecated public class DeleteDatabasePlan extends ConfigPhysicalPlan { private String name; @@ -37,7 +36,7 @@ public DeleteDatabasePlan() { super(ConfigPhysicalPlanType.DeleteDatabase); } - public DeleteDatabasePlan(final String name) { + public DeleteDatabasePlan(String name) { this(); this.name = name; } @@ -47,7 +46,7 @@ public String getName() { } @Override - protected void serializeImpl(final DataOutputStream stream) throws IOException { + protected void serializeImpl(DataOutputStream stream) throws IOException { stream.writeShort(getType().getPlanType()); BasicStructureSerDeUtil.write(name, stream); } @@ -58,7 +57,7 @@ protected void deserializeImpl(ByteBuffer buffer) { } @Override - public boolean equals(final Object o) { + public boolean equals(Object o) { if (this == o) { return true; } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java index 2035e108d091..1718fcb68cfb 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/extractor/ConfigRegionListeningFilter.java @@ -67,9 +67,7 @@ public class ConfigRegionListeningFilter { Collections.singletonList(ConfigPhysicalPlanType.AlterDatabase)); OPTION_PLAN_MAP.put( new PartialPath("schema.database.drop"), - Collections.unmodifiableList( - Arrays.asList( - ConfigPhysicalPlanType.DeleteDatabase, ConfigPhysicalPlanType.DeleteDatabaseV2))); + Collections.singletonList(ConfigPhysicalPlanType.DeleteDatabase)); OPTION_PLAN_MAP.put( new PartialPath("schema.timeseries.template.create"), diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java index 418b226a4669..5a67005110a2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/pipe/receiver/protocol/IoTDBConfigNodeReceiver.java @@ -251,11 +251,6 @@ private TSStatus executePlan(final ConfigPhysicalPlan plan) throws ConsensusExce new TDeleteDatabasesReq( Collections.singletonList(((DeleteDatabasePlan) plan).getName())) .setIsGeneratedByPipe(true)); - case DeleteDatabaseV2: - return configManager.deleteDatabases( - new TDeleteDatabasesReq( - Collections.singletonList(((DatabaseSchemaPlan) plan).getSchema().getName())) - .setIsGeneratedByPipe(true)); case ExtendSchemaTemplate: return configManager .getClusterSchemaManager() diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java index 4ec74740e05f..9a1f989db5ac 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/schema/ClusterSchemaManager.java @@ -50,6 +50,7 @@ import org.apache.iotdb.confignode.consensus.request.read.template.GetTemplateSetInfoPlan; import org.apache.iotdb.confignode.consensus.request.write.database.AdjustMaxRegionGroupNumPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; +import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetDataReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetSchemaReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetTimePartitionIntervalPlan; @@ -268,7 +269,7 @@ public TSStatus alterDatabase( /** Delete DatabaseSchema. */ public TSStatus deleteDatabase( - final DatabaseSchemaPlan deleteDatabasePlan, final boolean isGeneratedByPipe) { + final DeleteDatabasePlan deleteDatabasePlan, final boolean isGeneratedByPipe) { TSStatus result; try { result = diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java index 38ec64a63493..804be5986ecc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/executor/ConfigPlanExecutor.java @@ -404,18 +404,9 @@ public TSStatus executeNonQueryPlan(ConfigPhysicalPlan physicalPlan) (AdjustMaxRegionGroupNumPlan) physicalPlan); case DeleteDatabase: try { - return clusterSchemaInfo.deleteDatabase( - ((DeleteDatabasePlan) physicalPlan).getName(), false); + return clusterSchemaInfo.deleteDatabase((DeleteDatabasePlan) physicalPlan); } finally { - partitionInfo.deleteDatabase(((DeleteDatabasePlan) physicalPlan).getName()); - } - case DeleteDatabaseV2: - try { - final TDatabaseSchema schema = ((DatabaseSchemaPlan) physicalPlan).getSchema(); - return clusterSchemaInfo.deleteDatabase( - schema.getName(), schema.isSetIsTableModel() && schema.isIsTableModel()); - } finally { - partitionInfo.deleteDatabase(((DatabaseSchemaPlan) physicalPlan).getSchema().getName()); + partitionInfo.deleteDatabase((DeleteDatabasePlan) physicalPlan); } case PreDeleteDatabase: return partitionInfo.preDeleteDatabase((PreDeleteDatabasePlan) physicalPlan); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index 943f2bcd47a5..c96d4a95eeeb 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -38,6 +38,7 @@ import org.apache.iotdb.confignode.consensus.request.read.region.GetRegionIdPlan; import org.apache.iotdb.confignode.consensus.request.read.region.GetRegionInfoListPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; +import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.datanode.UpdateDataNodePlan; import org.apache.iotdb.confignode.consensus.request.write.partition.AddRegionLocationPlan; @@ -309,11 +310,11 @@ public boolean isDatabasePreDeleted(String database) { /** * Thread-safely delete database. * - * @param databaseName databaseName + * @param plan DeleteDatabasePlan */ - public void deleteDatabase(final String databaseName) { - // Clean the StorageGroupTable cache - databasePartitionTables.remove(databaseName); + public void deleteDatabase(DeleteDatabasePlan plan) { + // Clean the databaseTable cache + databasePartitionTables.remove(plan.getName()); } /** diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 6401a87d9e3a..5189dfe6d23c 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -44,6 +44,7 @@ import org.apache.iotdb.confignode.consensus.request.read.template.GetTemplateSetInfoPlan; import org.apache.iotdb.confignode.consensus.request.write.database.AdjustMaxRegionGroupNumPlan; import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; +import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetDataReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetSchemaReplicationFactorPlan; import org.apache.iotdb.confignode.consensus.request.write.database.SetTimePartitionIntervalPlan; @@ -270,16 +271,16 @@ public TSStatus alterDatabase(final DatabaseSchemaPlan plan) { /** * Delete Database. * - * @param databaseName dbName + * @param plan DeleteDatabasePlan * @return {@link TSStatusCode#SUCCESS_STATUS} */ - public TSStatus deleteDatabase(final String databaseName, final boolean isTableModel) { + public TSStatus deleteDatabase(final DeleteDatabasePlan plan) { final TSStatus result = new TSStatus(); databaseReadWriteLock.writeLock().lock(); try { // Delete Database - (isTableModel ? tableModelMTree : treeModelMTree) - .deleteDatabase(getQualifiedDatabasePartialPath(databaseName)); + // TODO: Use TDatabaseSchema + treeModelMTree.deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); result.setCode(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (final MetadataException e) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java index 663ccd0d7104..f5cee035c2ca 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/env/ConfigNodeProcedureEnv.java @@ -39,7 +39,7 @@ import org.apache.iotdb.confignode.client.sync.SyncConfigNodeClientPool; import org.apache.iotdb.confignode.client.sync.SyncDataNodeClientPool; import org.apache.iotdb.confignode.consensus.request.write.confignode.RemoveConfigNodePlan; -import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; +import org.apache.iotdb.confignode.consensus.request.write.database.DeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.region.CreateRegionGroupsPlan; import org.apache.iotdb.confignode.exception.AddConsensusGroupException; @@ -133,13 +133,13 @@ public ConfigManager getConfigManager() { /** * Delete ConfigNode cache, includes {@link ClusterSchemaInfo} and {@link PartitionInfo}. * - * @param plan databaseSchemaPlan + * @param name database name * @param isGeneratedByPipe whether the deletion is triggered by pipe request * @return tsStatus */ - public TSStatus deleteDatabaseConfig( - final DatabaseSchemaPlan plan, final boolean isGeneratedByPipe) { - return getClusterSchemaManager().deleteDatabase(plan, isGeneratedByPipe); + public TSStatus deleteDatabaseConfig(final String name, final boolean isGeneratedByPipe) { + final DeleteDatabasePlan deleteDatabasePlan = new DeleteDatabasePlan(name); + return getClusterSchemaManager().deleteDatabase(deleteDatabasePlan, isGeneratedByPipe); } /** diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java index 19bb31d465b6..6c8a679b9f3b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteDatabaseProcedure.java @@ -30,8 +30,6 @@ import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; -import org.apache.iotdb.confignode.consensus.request.ConfigPhysicalPlanType; -import org.apache.iotdb.confignode.consensus.request.write.database.DatabaseSchemaPlan; import org.apache.iotdb.confignode.consensus.request.write.database.PreDeleteDatabasePlan; import org.apache.iotdb.confignode.consensus.request.write.region.OfferRegionMaintainTasksPlan; import org.apache.iotdb.confignode.manager.partition.PartitionMetrics; @@ -207,10 +205,7 @@ protected Flow executeFromState( // Delete DatabasePartitionTable final TSStatus deleteConfigResult = - env.deleteDatabaseConfig( - new DatabaseSchemaPlan( - ConfigPhysicalPlanType.DeleteDatabaseV2, deleteDatabaseSchema), - isGeneratedByPipe); + env.deleteDatabaseConfig(deleteDatabaseSchema.getName(), isGeneratedByPipe); if (deleteConfigResult.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { LOG.info( @@ -314,7 +309,7 @@ public void deserialize(final ByteBuffer byteBuffer) { @Override public boolean equals(final Object that) { if (that instanceof DeleteDatabaseProcedure) { - final DeleteDatabaseProcedure thatProc = (DeleteDatabaseProcedure) that; + DeleteDatabaseProcedure thatProc = (DeleteDatabaseProcedure) that; return thatProc.getProcId() == this.getProcId() && thatProc.getCurrentState().equals(this.getCurrentState()) && thatProc.getCycles() == this.getCycles() From 3610d5bbb2fd25f552b4c74a7f3e62dfa95bdbf1 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Fri, 13 Dec 2024 19:18:10 +0800 Subject: [PATCH 51/71] Update ClusterSchemaInfo.java --- .../confignode/persistence/schema/ClusterSchemaInfo.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java index 5189dfe6d23c..d911e07e37f8 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/schema/ClusterSchemaInfo.java @@ -279,8 +279,8 @@ public TSStatus deleteDatabase(final DeleteDatabasePlan plan) { databaseReadWriteLock.writeLock().lock(); try { // Delete Database - // TODO: Use TDatabaseSchema - treeModelMTree.deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); + (PathUtils.isTableModelDatabase(plan.getName()) ? tableModelMTree : treeModelMTree) + .deleteDatabase(getQualifiedDatabasePartialPath(plan.getName())); result.setCode(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } catch (final MetadataException e) { From c05a79ebeeb92cbdee5426241219c297dade691e Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Mon, 16 Dec 2024 11:05:44 +0800 Subject: [PATCH 52/71] Fix --- .../iotdb/db/pipe/event/common/PipeInsertionEvent.java | 6 ++---- .../PipeHistoricalDataRegionTsFileAndDeletionExtractor.java | 2 +- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/event/common/PipeInsertionEvent.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/event/common/PipeInsertionEvent.java index cb9182aff586..c80dd8bceff7 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/event/common/PipeInsertionEvent.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/event/common/PipeInsertionEvent.java @@ -23,6 +23,7 @@ import org.apache.iotdb.commons.pipe.datastructure.pattern.TablePattern; import org.apache.iotdb.commons.pipe.datastructure.pattern.TreePattern; import org.apache.iotdb.commons.pipe.event.EnrichedEvent; +import org.apache.iotdb.commons.utils.PathUtils; public abstract class PipeInsertionEvent extends EnrichedEvent { @@ -97,10 +98,7 @@ public String getTreeModelDatabaseName() { public String getTableModelDatabaseName() { return tableModelDatabaseName == null - ? tableModelDatabaseName = - treeModelDatabaseName != null && treeModelDatabaseName.startsWith("root.") - ? treeModelDatabaseName.substring(5) - : treeModelDatabaseName + ? tableModelDatabaseName = PathUtils.unQualifyDatabaseName(treeModelDatabaseName) : tableModelDatabaseName; } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java index 011bfcc389ab..a1d4ffe11867 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java @@ -661,7 +661,7 @@ private boolean mayTsFileResourceOverlappedWithPattern(final TsFileResource reso return isTableModel ? (tablePattern.isTableModelDataAllowedToBeCaptured() // The database name in resource is prefixed with "root." - && tablePattern.matchesDatabase(resource.getDatabaseName().substring(5)) + && tablePattern.matchesDatabase(resource.getDatabaseName()) && tablePattern.matchesTable(deviceID.getTableName())) : (treePattern.isTreeModelDataAllowedToBeCaptured() && treePattern.mayOverlapWithDevice(deviceID)); From 81c5538345bfffb2eb157e44227ee21f096326de Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Mon, 16 Dec 2024 14:56:00 +0800 Subject: [PATCH 53/71] Fix --- .../PipeHistoricalDataRegionTsFileAndDeletionExtractor.java | 5 ++--- .../dataregion/realtime/PipeRealtimeDataRegionExtractor.java | 4 +--- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java index a1d4ffe11867..5c4f8931b49a 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java @@ -322,8 +322,7 @@ public void customize( if (Objects.nonNull(databaseName)) { isDbNameCoveredByPattern = treePattern.coversDb(databaseName) - // The database name is prefixed with "root." - && tablePattern.coversDb(databaseName.substring(5)); + && tablePattern.coversDb(databaseName); } } @@ -678,7 +677,7 @@ private void detectModel(final TsFileResource resource, final IDeviceID deviceID isDbNameCoveredByPattern = isTableModel ? tablePattern.isTableModelDataAllowedToBeCaptured() - && tablePattern.coversDb(databaseName.substring(5)) + && tablePattern.coversDb(databaseName) : treePattern.isTreeModelDataAllowedToBeCaptured() && treePattern.coversDb(databaseName); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/realtime/PipeRealtimeDataRegionExtractor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/realtime/PipeRealtimeDataRegionExtractor.java index 568e863acf40..6957ccfdbc36 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/realtime/PipeRealtimeDataRegionExtractor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/realtime/PipeRealtimeDataRegionExtractor.java @@ -221,9 +221,7 @@ public void customize( final String databaseName = dataRegion.getDatabaseName(); if (databaseName != null) { isDbNameCoveredByPattern = - treePattern.coversDb(databaseName) - // The database name is prefixed with "root." - && tablePattern.coversDb(databaseName.substring(5)); + treePattern.coversDb(databaseName) && tablePattern.coversDb(databaseName); } } From a32d9988f0dd8fa9b068a20874ce72ceb43199cc Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Mon, 16 Dec 2024 14:56:25 +0800 Subject: [PATCH 54/71] Update PipeHistoricalDataRegionTsFileAndDeletionExtractor.java --- .../PipeHistoricalDataRegionTsFileAndDeletionExtractor.java | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java index 5c4f8931b49a..1f9f13846f96 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/extractor/dataregion/historical/PipeHistoricalDataRegionTsFileAndDeletionExtractor.java @@ -321,8 +321,7 @@ public void customize( final String databaseName = dataRegion.getDatabaseName(); if (Objects.nonNull(databaseName)) { isDbNameCoveredByPattern = - treePattern.coversDb(databaseName) - && tablePattern.coversDb(databaseName); + treePattern.coversDb(databaseName) && tablePattern.coversDb(databaseName); } } @@ -659,7 +658,6 @@ private boolean mayTsFileResourceOverlappedWithPattern(final TsFileResource reso return isTableModel ? (tablePattern.isTableModelDataAllowedToBeCaptured() - // The database name in resource is prefixed with "root." && tablePattern.matchesDatabase(resource.getDatabaseName()) && tablePattern.matchesTable(deviceID.getTableName())) : (treePattern.isTreeModelDataAllowedToBeCaptured() From 77f550578891d7b74162133147be71bfa562b16b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Mon, 16 Dec 2024 16:33:26 +0800 Subject: [PATCH 55/71] Update ClusterConfigTaskExecutor.java --- .../execution/config/executor/ClusterConfigTaskExecutor.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 1c12f1f4eca6..a80097d27e58 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -3574,7 +3574,7 @@ public SettableFuture deleteDevice( final TDeleteTableDeviceReq req = new TDeleteTableDeviceReq( - PathUtils.qualifyDatabaseName(deleteDevice.getDatabase()), + deleteDevice.getDatabase(), deleteDevice.getTableName(), queryId, ByteBuffer.wrap(patternStream.toByteArray()), From a9b6a79218047a842e21cdec3eee4a19afa6ec1e Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 09:37:53 +0800 Subject: [PATCH 56/71] Update TableConfigTaskVisitor.java --- .../plan/execution/config/TableConfigTaskVisitor.java | 1 - 1 file changed, 1 deletion(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java index bb94f655fb38..7454c724e252 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/TableConfigTaskVisitor.java @@ -509,7 +509,6 @@ protected IConfigTask visitSetProperties( public static void validateDatabaseName(final String dbName) throws SemanticException { // Check database length here - // We need to calculate the database name without "root." if (dbName.contains(PATH_SEPARATOR) || !IoTDBConfig.STORAGE_GROUP_PATTERN.matcher(dbName).matches() || dbName.length() > MAX_DATABASE_NAME_LENGTH) { From c38e2360b5141d6881408428dcebcfa265aaef3b Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 09:53:23 +0800 Subject: [PATCH 57/71] Bug fix --- .../receiver/protocol/thrift/IoTDBDataNodeReceiver.java | 5 +---- .../plan/analyze/load/LoadTsFileToTableModelAnalyzer.java | 5 +---- .../config/executor/ClusterConfigTaskExecutor.java | 7 +------ 3 files changed, 3 insertions(+), 14 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/receiver/protocol/thrift/IoTDBDataNodeReceiver.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/receiver/protocol/thrift/IoTDBDataNodeReceiver.java index 47b8de606f4c..8ac1fb6a380b 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/receiver/protocol/thrift/IoTDBDataNodeReceiver.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/pipe/receiver/protocol/thrift/IoTDBDataNodeReceiver.java @@ -127,8 +127,6 @@ import static org.apache.iotdb.db.exception.metadata.DatabaseNotSetException.DATABASE_NOT_SET; import static org.apache.iotdb.db.utils.ErrorHandlingUtils.getRootCause; -import static org.apache.iotdb.db.utils.constant.SqlConstant.ROOT; -import static org.apache.tsfile.common.constant.TsFileConstant.PATH_SEPARATOR_CHAR; public class IoTDBDataNodeReceiver extends IoTDBFileReceiver { @@ -873,8 +871,7 @@ private void autoCreateDatabaseIfNecessary(final String database) { return; } - final TDatabaseSchema schema = - new TDatabaseSchema(new TDatabaseSchema(ROOT + PATH_SEPARATOR_CHAR + database)); + final TDatabaseSchema schema = new TDatabaseSchema(new TDatabaseSchema(database)); schema.setIsTableModel(true); final CreateDBTask task = new CreateDBTask(schema, true); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/load/LoadTsFileToTableModelAnalyzer.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/load/LoadTsFileToTableModelAnalyzer.java index 33c1f73e6fc5..2975365ec94f 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/load/LoadTsFileToTableModelAnalyzer.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/load/LoadTsFileToTableModelAnalyzer.java @@ -60,8 +60,6 @@ import java.util.concurrent.ExecutionException; import static org.apache.iotdb.db.queryengine.plan.execution.config.TableConfigTaskVisitor.validateDatabaseName; -import static org.apache.iotdb.db.utils.constant.SqlConstant.ROOT; -import static org.apache.tsfile.common.constant.TsFileConstant.PATH_SEPARATOR_CHAR; public class LoadTsFileToTableModelAnalyzer extends LoadTsFileAnalyzer { private static final Logger LOGGER = @@ -192,8 +190,7 @@ private void autoCreateDatabaseIfAbsent(final String database) throws VerifyMeta } final CreateDBTask task = - new CreateDBTask( - new TDatabaseSchema(ROOT + PATH_SEPARATOR_CHAR + database).setIsTableModel(true), true); + new CreateDBTask(new TDatabaseSchema(database).setIsTableModel(true), true); try { final ListenableFuture future = task.execute(ClusterConfigTaskExecutor.getInstance()); diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index a80097d27e58..34a39c85fac0 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -3100,16 +3100,11 @@ public SettableFuture useDatabase( return future; } - private String transformDBName(final String dbName) { - return ROOT + PATH_SEPARATOR_CHAR + dbName; - } - @Override public SettableFuture dropDatabase(final DropDB dropDB) { final SettableFuture future = SettableFuture.create(); final TDeleteDatabasesReq req = - new TDeleteDatabasesReq( - Collections.singletonList(transformDBName(dropDB.getDbName().getValue()))) + new TDeleteDatabasesReq(Collections.singletonList(dropDB.getDbName().getValue())) .setIsTableModel(true); try (final ConfigNodeClient client = CONFIG_NODE_CLIENT_MANAGER.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { From 1206c46b29b1871311248c038ba5291e54224e01 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 09:59:28 +0800 Subject: [PATCH 58/71] Fix --- .../request/write/quota/SetSpaceQuotaPlan.java | 2 +- .../iotdb/confignode/manager/ClusterQuotaManager.java | 8 ++++---- .../service/thrift/ConfigNodeRPCServiceProcessor.java | 2 +- .../config/executor/ClusterConfigTaskExecutor.java | 1 - .../rescon/quotas/DataNodeSpaceQuotaManager.java | 11 ++++------- 5 files changed, 10 insertions(+), 14 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/quota/SetSpaceQuotaPlan.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/quota/SetSpaceQuotaPlan.java index 525bf4f76653..c5e8c0d3673b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/quota/SetSpaceQuotaPlan.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/consensus/request/write/quota/SetSpaceQuotaPlan.java @@ -39,7 +39,7 @@ public SetSpaceQuotaPlan() { super(ConfigPhysicalPlanType.setSpaceQuota); } - public SetSpaceQuotaPlan(List prefixPathList, TSpaceQuota spaceLimit) { + public SetSpaceQuotaPlan(final List prefixPathList, final TSpaceQuota spaceLimit) { super(ConfigPhysicalPlanType.setSpaceQuota); this.prefixPathList = prefixPathList; this.spaceLimit = spaceLimit; diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ClusterQuotaManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ClusterQuotaManager.java index cbfa1bc2fb2e..b6bff890f361 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ClusterQuotaManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ClusterQuotaManager.java @@ -72,7 +72,7 @@ public ClusterQuotaManager(IManager configManager, QuotaInfo quotaInfo) { regionDisk = new ConcurrentHashMap<>(); } - public TSStatus setSpaceQuota(TSetSpaceQuotaReq req) { + public TSStatus setSpaceQuota(final TSetSpaceQuotaReq req) { if (!checkSpaceQuota(req)) { return RpcUtils.getStatus( TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode(), @@ -80,12 +80,12 @@ public TSStatus setSpaceQuota(TSetSpaceQuotaReq req) { } // TODO: Datanode failed to receive rpc try { - TSStatus response = + final TSStatus response = configManager .getConsensusManager() .write(new SetSpaceQuotaPlan(req.getDatabase(), req.getSpaceLimit())); if (response.getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { - Map dataNodeLocationMap = + final Map dataNodeLocationMap = configManager.getNodeManager().getRegisteredDataNodeLocations(); DataNodeAsyncRequestContext clientHandler = new DataNodeAsyncRequestContext<>( @@ -95,7 +95,7 @@ public TSStatus setSpaceQuota(TSetSpaceQuotaReq req) { return RpcUtils.squashResponseStatusList(clientHandler.getResponseList()); } return response; - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn( String.format( "Unexpected error happened while setting space quota on database: %s ", diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 8221d365b20b..71c3d331ab95 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -1271,7 +1271,7 @@ public TGetModelInfoResp getModelInfo(TGetModelInfoReq req) { } @Override - public TSStatus setSpaceQuota(TSetSpaceQuotaReq req) throws TException { + public TSStatus setSpaceQuota(final TSetSpaceQuotaReq req) throws TException { return configManager.setSpaceQuota(req); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java index 34a39c85fac0..5e4d68b084c1 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/execution/config/executor/ClusterConfigTaskExecutor.java @@ -317,7 +317,6 @@ import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_RESULT_NODES; import static org.apache.iotdb.db.protocol.client.ConfigNodeClient.MSG_RECONNECTION_FAIL; import static org.apache.iotdb.db.utils.constant.SqlConstant.ROOT; -import static org.apache.tsfile.common.constant.TsFileConstant.PATH_SEPARATOR_CHAR; public class ClusterConfigTaskExecutor implements IConfigTaskExecutor { diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java index 9b1ef020b063..612c0871ecbc 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java @@ -22,7 +22,6 @@ import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.common.rpc.thrift.TSetSpaceQuotaReq; import org.apache.iotdb.common.rpc.thrift.TSpaceQuota; -import org.apache.iotdb.commons.conf.IoTDBConstant; import org.apache.iotdb.confignode.rpc.thrift.TSpaceQuotaResp; import org.apache.iotdb.db.queryengine.plan.execution.config.executor.ClusterConfigTaskExecutor; import org.apache.iotdb.rpc.RpcUtils; @@ -94,8 +93,7 @@ private void recover() { } } - public boolean checkDeviceLimit(String database) { - database = IoTDBConstant.PATH_ROOT + IoTDBConstant.PATH_SEPARATOR + database; + public boolean checkDeviceLimit(final String database) { final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getDeviceNum() == 0 @@ -109,8 +107,7 @@ public void updateSpaceQuotaUsage(final Map spaceQuotaUsage } } - public boolean checkTimeSeriesNum(String database) { - database = IoTDBConstant.PATH_ROOT + IoTDBConstant.PATH_SEPARATOR + database; + public boolean checkTimeSeriesNum(final String database) { final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getTimeserieNum() == 0 @@ -118,8 +115,8 @@ public boolean checkTimeSeriesNum(String database) { || spaceQuota.getTimeserieNum() - spaceQuotaUsage.get(database).getTimeserieNum() > 0; } - public boolean checkRegionDisk(String database) { - TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); + public boolean checkRegionDisk(final String database) { + final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getDiskSize() == 0 || spaceQuota.getDiskSize() == -1 From c3da48510e7553f7e7d9b424b66f3459a8f70a1c Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 10:01:00 +0800 Subject: [PATCH 59/71] Update DataNodeSpaceQuotaManager.java --- .../rescon/quotas/DataNodeSpaceQuotaManager.java | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java index 612c0871ecbc..9b1ef020b063 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/storageengine/rescon/quotas/DataNodeSpaceQuotaManager.java @@ -22,6 +22,7 @@ import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.common.rpc.thrift.TSetSpaceQuotaReq; import org.apache.iotdb.common.rpc.thrift.TSpaceQuota; +import org.apache.iotdb.commons.conf.IoTDBConstant; import org.apache.iotdb.confignode.rpc.thrift.TSpaceQuotaResp; import org.apache.iotdb.db.queryengine.plan.execution.config.executor.ClusterConfigTaskExecutor; import org.apache.iotdb.rpc.RpcUtils; @@ -93,7 +94,8 @@ private void recover() { } } - public boolean checkDeviceLimit(final String database) { + public boolean checkDeviceLimit(String database) { + database = IoTDBConstant.PATH_ROOT + IoTDBConstant.PATH_SEPARATOR + database; final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getDeviceNum() == 0 @@ -107,7 +109,8 @@ public void updateSpaceQuotaUsage(final Map spaceQuotaUsage } } - public boolean checkTimeSeriesNum(final String database) { + public boolean checkTimeSeriesNum(String database) { + database = IoTDBConstant.PATH_ROOT + IoTDBConstant.PATH_SEPARATOR + database; final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getTimeserieNum() == 0 @@ -115,8 +118,8 @@ public boolean checkTimeSeriesNum(final String database) { || spaceQuota.getTimeserieNum() - spaceQuotaUsage.get(database).getTimeserieNum() > 0; } - public boolean checkRegionDisk(final String database) { - final TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); + public boolean checkRegionDisk(String database) { + TSpaceQuota spaceQuota = spaceQuotaLimit.get(database); return spaceQuota == null || spaceQuota.getDiskSize() == 0 || spaceQuota.getDiskSize() == -1 From 65b62e3c1f0cfc5127fb5e913ca96880ab7a0c6d Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 11:56:02 +0800 Subject: [PATCH 60/71] Fix --- .../apache/iotdb/pipe/it/tablemodel/IoTDBPipeClusterIT.java | 3 ++- .../metadata/schemaRegion/SchemaRegionSimpleRecoverTest.java | 5 +---- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/integration-test/src/test/java/org/apache/iotdb/pipe/it/tablemodel/IoTDBPipeClusterIT.java b/integration-test/src/test/java/org/apache/iotdb/pipe/it/tablemodel/IoTDBPipeClusterIT.java index 83725d76bff8..f30ddebc6988 100644 --- a/integration-test/src/test/java/org/apache/iotdb/pipe/it/tablemodel/IoTDBPipeClusterIT.java +++ b/integration-test/src/test/java/org/apache/iotdb/pipe/it/tablemodel/IoTDBPipeClusterIT.java @@ -231,7 +231,8 @@ public void testPipeAfterDataRegionLeaderStop() throws Exception { } final AtomicInteger leaderPort = new AtomicInteger(-1); - final TShowRegionResp showRegionResp = client.showRegion(new TShowRegionReq()); + final TShowRegionResp showRegionResp = + client.showRegion(new TShowRegionReq().setIsTableModel(true)); showRegionResp .getRegionInfoList() .forEach( diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionSimpleRecoverTest.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionSimpleRecoverTest.java index cd37faea6c2d..25685bd9794a 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionSimpleRecoverTest.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/metadata/schemaRegion/SchemaRegionSimpleRecoverTest.java @@ -48,7 +48,6 @@ import org.apache.iotdb.isession.SessionConfig; import org.apache.tsfile.common.conf.TSFileConfig; -import org.apache.tsfile.common.constant.TsFileConstant; import org.apache.tsfile.enums.TSDataType; import org.apache.tsfile.file.metadata.enums.CompressionType; import org.apache.tsfile.file.metadata.enums.TSEncoding; @@ -67,7 +66,6 @@ import java.util.Map; import static org.apache.iotdb.commons.schema.SchemaConstant.ALL_MATCH_SCOPE; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; import static org.apache.iotdb.db.metadata.schemaRegion.SchemaRegionTestUtil.checkSingleTimeSeries; import static org.apache.iotdb.db.metadata.schemaRegion.SchemaRegionTestUtil.createTableDevice; @@ -273,8 +271,7 @@ public void testRecoverAfterCreateAndUpdateDevice() throws Exception { new ColumnHeader("d_1", TSDataType.STRING)); final String attributeName = "attr"; - ISchemaRegion schemaRegion = - getSchemaRegion(ROOT + TsFileConstant.PATH_SEPARATOR + database, 0); + ISchemaRegion schemaRegion = getSchemaRegion(database, 0); createTableDevice( schemaRegion, tableName, From d2883833c48f06b6b28b04956355c078fdd7d5ae Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 14:41:25 +0800 Subject: [PATCH 61/71] partial --- .../confignode/manager/ConfigManager.java | 35 ++++++++++----- .../iotdb/confignode/manager/IManager.java | 7 +++ .../manager/partition/PartitionManager.java | 45 ++++++++++--------- .../partition/DatabasePartitionTable.java | 5 ++- .../persistence/partition/PartitionInfo.java | 14 +++--- .../schema/table/DeleteDevicesProcedure.java | 6 +-- .../table/DropTableColumnProcedure.java | 2 +- .../impl/schema/table/DropTableProcedure.java | 22 +-------- 8 files changed, 68 insertions(+), 68 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index ebdbddc4bf8e..08d7b52cbfa4 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -765,21 +765,22 @@ public synchronized TSStatus deleteDatabases(final TDeleteDatabasesReq tDeleteRe } } - private List calculateRelatedSlot(PartialPath path, PartialPath database) { + private List calculateRelatedSlot( + final PartialPath path, final PartialPath database) { // The path contains `**` if (path.getFullPath().contains(IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD)) { return new ArrayList<>(); } // with database = root.sg, path = root.*.d1 // convert path = root.sg.d1 - List innerPathList = path.alterPrefixPath(database); + final List innerPathList = path.alterPrefixPath(database); if (innerPathList.isEmpty()) { return new ArrayList<>(); } - String[] devicePath = + final String[] devicePath = Arrays.copyOf(innerPathList.get(0).getNodes(), innerPathList.get(0).getNodeLength() - 1); // root.sg1.*.d1 - for (String node : devicePath) { + for (final String node : devicePath) { if (node.contains(IoTDBConstant.ONE_LEVEL_PATH_WILDCARD)) { return Collections.emptyList(); } @@ -834,9 +835,14 @@ public TSchemaPartitionTableResp getSchemaPartition( return getSchemaPartition(databaseSlotMap); } + @Override + public TSchemaPartitionTableResp getSchemaPartition4TableModel(final String database) { + return getSchemaPartition(Collections.singletonMap(database, Collections.emptyList())); + } + @Override public TSchemaPartitionTableResp getSchemaPartition( - Map> dbSlotMap) { + final Map> dbSlotMap) { // Construct empty response TSchemaPartitionTableResp resp = new TSchemaPartitionTableResp(); // Return empty resp if the partitionSlotsMap is empty @@ -844,11 +850,12 @@ public TSchemaPartitionTableResp getSchemaPartition( return resp.setStatus(StatusUtils.OK).setSchemaPartitionTable(new HashMap<>()); } - GetSchemaPartitionPlan getSchemaPartitionPlan = + final GetSchemaPartitionPlan getSchemaPartitionPlan = new GetSchemaPartitionPlan( dbSlotMap.entrySet().stream() .collect(Collectors.toMap(Map.Entry::getKey, e -> new ArrayList<>(e.getValue())))); - SchemaPartitionResp queryResult = partitionManager.getSchemaPartition(getSchemaPartitionPlan); + final SchemaPartitionResp queryResult = + partitionManager.getSchemaPartition(getSchemaPartitionPlan); resp = queryResult.convertToRpcSchemaPartitionTableResp(); LOGGER.debug("GetSchemaPartition receive paths: {}, return: {}", dbSlotMap, resp); @@ -2404,14 +2411,18 @@ public TShowCQResp showCQ() { */ public Map getRelatedSchemaRegionGroup( final PathPatternTree patternTree) { - return getRelatedSchemaRegionGroup(patternTree, false); + return getRelatedSchemaRegionGroup( + getSchemaPartition(patternTree, false).getSchemaPartitionTable()); } - public Map getRelatedSchemaRegionGroup( - final PathPatternTree patternTree, final boolean isTableModel) { - final Map> schemaPartitionTable = - getSchemaPartition(patternTree, isTableModel).getSchemaPartitionTable(); + public Map getRelatedSchemaRegionGroup4TableModel( + final String database) { + return getRelatedSchemaRegionGroup( + getSchemaPartition4TableModel(database).getSchemaPartitionTable()); + } + private Map getRelatedSchemaRegionGroup( + final Map> schemaPartitionTable) { final List allRegionReplicaSets = getPartitionManager().getAllReplicaSets(); final Set groupIdSet = schemaPartitionTable.values().stream() diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java index 526c66612995..cae5b6c1633d 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java @@ -424,6 +424,13 @@ public interface IManager { TSchemaPartitionTableResp getSchemaPartition( final PathPatternTree patternTree, final boolean isTableModel); + /** + * Get SchemaPartition. + * + * @return TSchemaPartitionResp + */ + TSchemaPartitionTableResp getSchemaPartition4TableModel(final String database); + /** * Get SchemaPartition with . * diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java index 22d8ffad02ac..3c3045fdc0c1 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/partition/PartitionManager.java @@ -990,17 +990,17 @@ public SchemaNodeManagementResp getNodePathsPartition(GetNodePathsPartitionPlan } public void preDeleteDatabase( - String database, PreDeleteDatabasePlan.PreDeleteType preDeleteType) { + final String database, final PreDeleteDatabasePlan.PreDeleteType preDeleteType) { final PreDeleteDatabasePlan preDeleteDatabasePlan = new PreDeleteDatabasePlan(database, preDeleteType); try { getConsensusManager().write(preDeleteDatabasePlan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_WRITE_ERROR, e); } } - public boolean isDatabasePreDeleted(String database) { + public boolean isDatabasePreDeleted(final String database) { return partitionInfo.isDatabasePreDeleted(database); } @@ -1010,16 +1010,17 @@ public boolean isDatabasePreDeleted(String database) { * @param deviceID IDeviceID * @return SeriesPartitionSlot */ - public TSeriesPartitionSlot getSeriesPartitionSlot(IDeviceID deviceID) { + public TSeriesPartitionSlot getSeriesPartitionSlot(final IDeviceID deviceID) { return executor.getSeriesPartitionSlot(deviceID); } - public RegionInfoListResp getRegionInfoList(GetRegionInfoListPlan req) { + public RegionInfoListResp getRegionInfoList(final GetRegionInfoListPlan req) { try { // Get static result - RegionInfoListResp regionInfoListResp = (RegionInfoListResp) getConsensusManager().read(req); + final RegionInfoListResp regionInfoListResp = + (RegionInfoListResp) getConsensusManager().read(req); // Get cached result - Map allLeadership = getLoadManager().getRegionLeaderMap(); + final Map allLeadership = getLoadManager().getRegionLeaderMap(); regionInfoListResp .getRegionInfoList() .forEach( @@ -1030,7 +1031,7 @@ public RegionInfoListResp getRegionInfoList(GetRegionInfoListPlan req) { regionInfo.getConsensusGroupId(), regionInfo.getDataNodeId()) .getStatus()); - String regionType = + final String regionType = regionInfo.getDataNodeId() == allLeadership.getOrDefault(regionInfo.getConsensusGroupId(), -1) ? RegionRoleType.Leader.toString() @@ -1040,11 +1041,11 @@ public RegionInfoListResp getRegionInfoList(GetRegionInfoListPlan req) { return regionInfoListResp; - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_READ_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); - RegionInfoListResp resp = new RegionInfoListResp(); + final RegionInfoListResp resp = new RegionInfoListResp(); resp.setStatus(res); return resp; } @@ -1055,38 +1056,38 @@ public RegionInfoListResp getRegionInfoList(GetRegionInfoListPlan req) { * * @param regionGroupId The specified RegionGroup */ - public boolean isRegionGroupExists(TConsensusGroupId regionGroupId) { + public boolean isRegionGroupExists(final TConsensusGroupId regionGroupId) { return partitionInfo.isRegionGroupExisted(regionGroupId); } - public TSStatus addRegionLocation(AddRegionLocationPlan req) { + public TSStatus addRegionLocation(final AddRegionLocationPlan req) { try { return getConsensusManager().write(req); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_WRITE_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); return res; } } - public TSStatus removeRegionLocation(RemoveRegionLocationPlan req) { + public TSStatus removeRegionLocation(final RemoveRegionLocationPlan req) { try { return getConsensusManager().write(req); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_WRITE_ERROR, e); - TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); + final TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); return res; } } - public GetRegionIdResp getRegionId(TGetRegionIdReq req) { - GetRegionIdPlan plan = new GetRegionIdPlan(req.getType()); + public GetRegionIdResp getRegionId(final TGetRegionIdReq req) { + final GetRegionIdPlan plan = new GetRegionIdPlan(req.getType()); if (req.isSetDatabase()) { plan.setDatabase(req.getDatabase()); } else { - IDeviceID deviceID = + final IDeviceID deviceID = Deserializer.DEFAULT_DESERIALIZER.deserializeFrom(ByteBuffer.wrap(req.getDevice())); plan.setDatabase(getClusterSchemaManager().getDatabaseNameByDevice(deviceID)); plan.setSeriesSlotId(executor.getSeriesPartitionSlot(deviceID)); @@ -1108,7 +1109,7 @@ public GetRegionIdResp getRegionId(TGetRegionIdReq req) { try { return (GetRegionIdResp) getConsensusManager().read(plan); - } catch (ConsensusException e) { + } catch (final ConsensusException e) { LOGGER.warn(CONSENSUS_READ_ERROR, e); TSStatus res = new TSStatus(TSStatusCode.EXECUTE_STATEMENT_ERROR.getStatusCode()); res.setMessage(e.getMessage()); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/DatabasePartitionTable.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/DatabasePartitionTable.java index 1ff56a89bb0f..bb9e26e9dda3 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/DatabasePartitionTable.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/DatabasePartitionTable.java @@ -274,7 +274,7 @@ public int getAssignedSeriesPartitionSlotsCount() { * @return True if all the SeriesPartitionSlots are matched, false otherwise */ public boolean getSchemaPartition( - List partitionSlots, SchemaPartitionTable schemaPartition) { + final List partitionSlots, final SchemaPartitionTable schemaPartition) { return schemaPartitionTable.getSchemaPartition(partitionSlots, schemaPartition); } @@ -286,7 +286,8 @@ public boolean getSchemaPartition( * @return True if all the PartitionSlots are matched, false otherwise */ public boolean getDataPartition( - Map partitionSlots, DataPartitionTable dataPartition) { + final Map partitionSlots, + final DataPartitionTable dataPartition) { return dataPartitionTable.getDataPartition(partitionSlots, dataPartition); } diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java index c96d4a95eeeb..492aceb2feca 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/persistence/partition/PartitionInfo.java @@ -281,11 +281,11 @@ public List getRegionMaintainEntryList() { * @param preDeleteDatabasePlan PreDeleteStorageGroupPlan * @return {@link TSStatusCode#SUCCESS_STATUS} */ - public TSStatus preDeleteDatabase(PreDeleteDatabasePlan preDeleteDatabasePlan) { + public TSStatus preDeleteDatabase(final PreDeleteDatabasePlan preDeleteDatabasePlan) { final PreDeleteDatabasePlan.PreDeleteType preDeleteType = preDeleteDatabasePlan.getPreDeleteType(); final String database = preDeleteDatabasePlan.getStorageGroup(); - DatabasePartitionTable databasePartitionTable = databasePartitionTables.get(database); + final DatabasePartitionTable databasePartitionTable = databasePartitionTables.get(database); if (databasePartitionTable == null) { return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } @@ -302,7 +302,7 @@ public TSStatus preDeleteDatabase(PreDeleteDatabasePlan preDeleteDatabasePlan) { return new TSStatus(TSStatusCode.SUCCESS_STATUS.getStatusCode()); } - public boolean isDatabasePreDeleted(String database) { + public boolean isDatabasePreDeleted(final String database) { DatabasePartitionTable databasePartitionTable = databasePartitionTables.get(database); return databasePartitionTable != null && !databasePartitionTable.isNotPreDeleted(); } @@ -312,7 +312,7 @@ public boolean isDatabasePreDeleted(String database) { * * @param plan DeleteDatabasePlan */ - public void deleteDatabase(DeleteDatabasePlan plan) { + public void deleteDatabase(final DeleteDatabasePlan plan) { // Clean the databaseTable cache databasePartitionTables.remove(plan.getName()); } @@ -323,10 +323,10 @@ public void deleteDatabase(DeleteDatabasePlan plan) { * @param plan SchemaPartitionPlan with partitionSlotsMap * @return SchemaPartitionDataSet that contains only existing SchemaPartition */ - public DataSet getSchemaPartition(GetSchemaPartitionPlan plan) { - AtomicBoolean isAllPartitionsExist = new AtomicBoolean(true); + public DataSet getSchemaPartition(final GetSchemaPartitionPlan plan) { + final AtomicBoolean isAllPartitionsExist = new AtomicBoolean(true); // TODO: Replace this map with new SchemaPartition - Map schemaPartition = new ConcurrentHashMap<>(); + final Map schemaPartition = new ConcurrentHashMap<>(); if (plan.getPartitionSlotsMap().isEmpty()) { // Return all SchemaPartitions when the queried PartitionSlots are empty diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java index cc804dbf7ac2..854c86ebf905 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java @@ -172,7 +172,7 @@ private void constructBlackList(final ConfigNodeProcedureEnv env) { } final Map relatedSchemaRegionGroup = - env.getConfigManager().getRelatedSchemaRegionGroup(patternTree, true); + env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database); if (relatedSchemaRegionGroup.isEmpty()) { deletedDevicesNum = 0; @@ -285,7 +285,7 @@ private void deleteDeviceSchema(final ConfigNodeProcedureEnv env) { new TableRegionTaskExecutor<>( "roll back table device black list", env, - env.getConfigManager().getRelatedSchemaRegionGroup(patternTree, true), + env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database), CnToDnAsyncRequestType.DELETE_TABLE_DEVICE_IN_BLACK_LIST, (dataNodeLocation, consensusGroupIdList) -> new TTableDeviceDeletionWithPatternOrModReq( @@ -301,7 +301,7 @@ protected void rollbackState( new TableRegionTaskExecutor<>( "roll back table device black list", env, - env.getConfigManager().getRelatedSchemaRegionGroup(patternTree, true), + env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database), CnToDnAsyncRequestType.ROLLBACK_TABLE_DEVICE_BLACK_LIST, (dataNodeLocation, consensusGroupIdList) -> new TTableDeviceDeletionWithPatternOrModReq( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java index 9b8a7dd10927..fbefd71d6d00 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java @@ -194,7 +194,7 @@ private void executeOnRegions(final ConfigNodeProcedureEnv env) { final Map relatedRegionGroup = isAttributeColumn - ? env.getConfigManager().getRelatedSchemaRegionGroup(patternTree, true) + ? env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database) : env.getConfigManager().getRelatedDataRegionGroup(patternTree, true); if (!relatedRegionGroup.isEmpty()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java index 7abfdc63c2d2..e587d9973820 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java @@ -51,7 +51,6 @@ import java.io.IOException; import java.util.ArrayList; import java.util.Map; -import java.util.Objects; import static org.apache.iotdb.commons.conf.IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD; import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; @@ -60,9 +59,6 @@ public class DropTableProcedure extends AbstractAlterOrDropTableProcedure relatedSchemaRegionGroup = - env.getConfigManager().getRelatedSchemaRegionGroup(patternTree, true); + env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database); if (!relatedSchemaRegionGroup.isEmpty()) { new TableRegionTaskExecutor<>( From 48af0add96bc964ddf597c68561c973d1a385e25 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:04:01 +0800 Subject: [PATCH 62/71] Fix --- .../confignode/manager/ConfigManager.java | 16 +++++++++---- .../schema/DeactivateTemplateProcedure.java | 2 +- .../schema/DeleteTimeSeriesProcedure.java | 2 +- .../schema/table/DeleteDevicesProcedure.java | 23 +------------------ .../table/DropTableColumnProcedure.java | 21 +---------------- .../impl/schema/table/DropTableProcedure.java | 21 +---------------- 6 files changed, 17 insertions(+), 68 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index 08d7b52cbfa4..7eb0f45c5048 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -2442,11 +2442,19 @@ private Map getRelatedSchemaRegionGroup( * patternTree */ public Map getRelatedDataRegionGroup( - final PathPatternTree patternTree, final boolean isTableModel) { - // Get all databases and slots by getting schemaengine partition - final Map> schemaPartitionTable = - getSchemaPartition(patternTree, isTableModel).getSchemaPartitionTable(); + final PathPatternTree patternTree) { + return getRelatedDataRegionGroup( + getSchemaPartition(patternTree, false).getSchemaPartitionTable()); + } + public Map getRelatedDataRegionGroup4TableModel( + final String database) { + return getRelatedDataRegionGroup( + getSchemaPartition4TableModel(database).getSchemaPartitionTable()); + } + + private Map getRelatedDataRegionGroup( + final Map> schemaPartitionTable) { // Construct request for getting data partition final Map> partitionSlotsMap = new HashMap<>(); schemaPartitionTable.forEach( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeactivateTemplateProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeactivateTemplateProcedure.java index ba987a454f33..cffa43f3f73c 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeactivateTemplateProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeactivateTemplateProcedure.java @@ -223,7 +223,7 @@ private void invalidateCache(final ConfigNodeProcedureEnv env) { private void deleteData(final ConfigNodeProcedureEnv env) { final Map relatedDataRegionGroup = - env.getConfigManager().getRelatedDataRegionGroup(timeSeriesPatternTree, false); + env.getConfigManager().getRelatedDataRegionGroup(timeSeriesPatternTree); // target timeSeries has no data or no target timeSeries, return directly if (!relatedDataRegionGroup.isEmpty() && !timeSeriesPatternTree.isEmpty()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteTimeSeriesProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteTimeSeriesProcedure.java index 2ea3640877ff..d95b35f62863 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteTimeSeriesProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/DeleteTimeSeriesProcedure.java @@ -235,7 +235,7 @@ private void executeDeleteData( } final Map relatedDataRegionGroup = - env.getConfigManager().getRelatedDataRegionGroup(patternTree, false); + env.getConfigManager().getRelatedDataRegionGroup(patternTree); // Target timeSeries has no data if (relatedDataRegionGroup.isEmpty()) { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java index 854c86ebf905..b039526d7179 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DeleteDevicesProcedure.java @@ -25,8 +25,6 @@ import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.commons.exception.IoTDBException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; -import org.apache.iotdb.commons.path.PathPatternTree; import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; @@ -48,7 +46,6 @@ import javax.annotation.Nonnull; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.nio.ByteBuffer; @@ -59,8 +56,6 @@ import java.util.Objects; import java.util.Set; -import static org.apache.iotdb.commons.conf.IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; import static org.apache.iotdb.confignode.procedure.state.schema.DeleteDevicesState.CHECK_TABLE_EXISTENCE; import static org.apache.iotdb.confignode.procedure.state.schema.DeleteDevicesState.CLEAN_DATANODE_SCHEMA_CACHE; import static org.apache.iotdb.confignode.procedure.state.schema.DeleteDevicesState.CONSTRUCT_BLACK_LIST; @@ -74,9 +69,6 @@ public class DeleteDevicesProcedure extends AbstractAlterOrDropTableProcedure relatedSchemaRegionGroup = env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database); @@ -272,7 +251,7 @@ private void deleteData(final ConfigNodeProcedureEnv env) { new TableRegionTaskExecutor<>( "delete data for table device", env, - env.getConfigManager().getRelatedDataRegionGroup(patternTree, true), + env.getConfigManager().getRelatedDataRegionGroup4TableModel(database), CnToDnAsyncRequestType.DELETE_DATA_FOR_TABLE_DEVICE, (dataNodeLocation, consensusGroupIdList) -> new TTableDeviceDeletionWithPatternOrModReq( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java index fbefd71d6d00..42523cd02a8b 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableColumnProcedure.java @@ -25,8 +25,6 @@ import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.commons.exception.IoTDBException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; -import org.apache.iotdb.commons.path.PathPatternTree; import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; @@ -47,7 +45,6 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.nio.ByteBuffer; @@ -55,9 +52,6 @@ import java.util.Map; import java.util.Objects; -import static org.apache.iotdb.commons.conf.IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; - public class DropTableColumnProcedure extends AbstractAlterOrDropTableProcedure { @@ -179,23 +173,10 @@ private void invalidateCache(final ConfigNodeProcedureEnv env) { } private void executeOnRegions(final ConfigNodeProcedureEnv env) { - final PathPatternTree patternTree = new PathPatternTree(); - final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); - final PartialPath path; - try { - path = new PartialPath(new String[] {ROOT, database, tableName}); - patternTree.appendPathPattern(path); - patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); - patternTree.serialize(dataOutputStream); - } catch (final IOException e) { - LOGGER.warn("failed to serialize request for table {}.{}", database, table.getTableName(), e); - } - final Map relatedRegionGroup = isAttributeColumn ? env.getConfigManager().getRelatedSchemaRegionGroup4TableModel(database) - : env.getConfigManager().getRelatedDataRegionGroup(patternTree, true); + : env.getConfigManager().getRelatedDataRegionGroup4TableModel(database); if (!relatedRegionGroup.isEmpty()) { new TableRegionTaskExecutor<>( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java index e587d9973820..1513287b24bc 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/table/DropTableProcedure.java @@ -25,8 +25,6 @@ import org.apache.iotdb.common.rpc.thrift.TSStatus; import org.apache.iotdb.commons.exception.IoTDBException; import org.apache.iotdb.commons.exception.MetadataException; -import org.apache.iotdb.commons.path.PartialPath; -import org.apache.iotdb.commons.path.PathPatternTree; import org.apache.iotdb.confignode.client.async.CnToDnAsyncRequestType; import org.apache.iotdb.confignode.client.async.CnToDnInternalServiceAsyncRequestManager; import org.apache.iotdb.confignode.client.async.handlers.DataNodeAsyncRequestContext; @@ -46,15 +44,11 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Map; -import static org.apache.iotdb.commons.conf.IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD; -import static org.apache.iotdb.commons.schema.SchemaConstant.ROOT; - public class DropTableProcedure extends AbstractAlterOrDropTableProcedure { private static final Logger LOGGER = LoggerFactory.getLogger(DropTableProcedure.class); @@ -150,21 +144,8 @@ private void invalidateCache(final ConfigNodeProcedureEnv env) { } private void deleteData(final ConfigNodeProcedureEnv env) { - patternTree = new PathPatternTree(); - final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - final DataOutputStream dataOutputStream = new DataOutputStream(byteArrayOutputStream); - final PartialPath path; - try { - path = new PartialPath(new String[] {ROOT, database, tableName}); - patternTree.appendPathPattern(path); - patternTree.appendPathPattern(path.concatAsMeasurementPath(MULTI_LEVEL_PATH_WILDCARD)); - patternTree.serialize(dataOutputStream); - } catch (final IOException e) { - LOGGER.warn("failed to serialize request for table {}.{}", database, table.getTableName(), e); - } - final Map relatedDataRegionGroup = - env.getConfigManager().getRelatedDataRegionGroup(patternTree, true); + env.getConfigManager().getRelatedDataRegionGroup4TableModel(database); if (!relatedDataRegionGroup.isEmpty()) { new TableRegionTaskExecutor<>( From e60ad30d9317f9f47f7a3309af5a42805ff6cfaa Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:38:28 +0800 Subject: [PATCH 63/71] may fix --- .../plan/analyze/ClusterPartitionFetcher.java | 24 +------------------ .../plan/analyze/IPartitionFetcher.java | 9 ------- .../metadata/TableMetadataImpl.java | 3 +-- 3 files changed, 2 insertions(+), 34 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index c92998a3d2cb..76c9945c8385 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -25,16 +25,13 @@ import org.apache.iotdb.common.rpc.thrift.TTimePartitionSlot; import org.apache.iotdb.commons.client.IClientManager; import org.apache.iotdb.commons.client.exception.ClientManagerException; -import org.apache.iotdb.commons.conf.IoTDBConstant; import org.apache.iotdb.commons.consensus.ConfigRegionId; -import org.apache.iotdb.commons.exception.IllegalPathException; import org.apache.iotdb.commons.exception.IoTDBException; import org.apache.iotdb.commons.partition.DataPartition; import org.apache.iotdb.commons.partition.DataPartitionQueryParam; import org.apache.iotdb.commons.partition.SchemaNodeManagementPartition; import org.apache.iotdb.commons.partition.SchemaPartition; import org.apache.iotdb.commons.partition.executor.SeriesPartitionExecutor; -import org.apache.iotdb.commons.path.PartialPath; import org.apache.iotdb.commons.path.PathPatternTree; import org.apache.iotdb.confignode.rpc.thrift.TDataPartitionReq; import org.apache.iotdb.confignode.rpc.thrift.TDataPartitionTableResp; @@ -45,7 +42,6 @@ import org.apache.iotdb.confignode.rpc.thrift.TTimeSlotList; import org.apache.iotdb.db.conf.IoTDBConfig; import org.apache.iotdb.db.conf.IoTDBDescriptor; -import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.exception.sql.StatementAnalyzeException; import org.apache.iotdb.db.protocol.client.ConfigNodeClient; import org.apache.iotdb.db.protocol.client.ConfigNodeClientManager; @@ -99,11 +95,6 @@ private ClusterPartitionFetcher() { @Override public SchemaPartition getSchemaPartition(final PathPatternTree patternTree) { - return getSchemaPartitionWithModel(patternTree, false); - } - - private SchemaPartition getSchemaPartitionWithModel( - final PathPatternTree patternTree, final boolean isTableModel) { try (final ConfigNodeClient client = configNodeClientManager.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { patternTree.constructTree(); @@ -113,7 +104,7 @@ private SchemaPartition getSchemaPartitionWithModel( SchemaPartition schemaPartition = partitionCache.getSchemaPartition(storageGroupToDeviceMap); if (null == schemaPartition) { final TSchemaPartitionTableResp schemaPartitionTableResp = - client.getSchemaPartitionTable(constructSchemaPartitionReq(patternTree, isTableModel)); + client.getSchemaPartitionTable(constructSchemaPartitionReq(patternTree, false)); if (schemaPartitionTableResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { schemaPartition = parseSchemaPartitionTableResp(schemaPartitionTableResp); @@ -356,19 +347,6 @@ private SchemaPartition getOrCreateSchemaPartition( } } - @Override - public SchemaPartition getSchemaPartition(final String database) { - final PathPatternTree patternTree = new PathPatternTree(); - try { - patternTree.appendPathPattern( - PartialPath.getDatabasePath(database) - .concatNode(IoTDBConstant.MULTI_LEVEL_PATH_WILDCARD)); - } catch (final IllegalPathException e) { - throw new SemanticException(e); - } - return getSchemaPartitionWithModel(patternTree, true); - } - /** split data partition query param by database */ private Map> splitDataPartitionQueryParam( final List dataPartitionQueryParams, diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java index c2859ac81349..43cf93dc291f 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java @@ -114,13 +114,4 @@ SchemaPartition getOrCreateSchemaPartition( *

The device id shall be [table, seg1, ....] */ SchemaPartition getSchemaPartition(final String database, final List deviceIDs); - - /** - * For data query with partial device id conditions. - * - *

The database shall start with "root.". Concat this to a user-provided db name if necessary. - * - *

The device id shall be [table, seg1, ....] - */ - SchemaPartition getSchemaPartition(final String database); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java index 0527d27b1fb4..b705e7739d26 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java @@ -28,7 +28,6 @@ import org.apache.iotdb.commons.udf.builtin.relational.TableBuiltinScalarFunction; import org.apache.iotdb.commons.udf.utils.TableUDFUtils; import org.apache.iotdb.commons.udf.utils.UDFDataTypeTransformer; -import org.apache.iotdb.commons.utils.PathUtils; import org.apache.iotdb.db.exception.sql.SemanticException; import org.apache.iotdb.db.queryengine.common.MPPQueryContext; import org.apache.iotdb.db.queryengine.common.SessionInfo; @@ -740,7 +739,7 @@ public SchemaPartition getSchemaPartition( @Override public SchemaPartition getSchemaPartition(final String database) { - return partitionFetcher.getSchemaPartition(PathUtils.qualifyDatabaseName(database)); + return partitionFetcher.getSchemaPartition(database, Collections.emptyList()); } @Override From 23ed88f54c6622317b21d15847005501050d62c1 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:46:25 +0800 Subject: [PATCH 64/71] Fix --- .../iotdb/confignode/manager/ConfigManager.java | 11 ++++------- .../org/apache/iotdb/confignode/manager/IManager.java | 7 ------- 2 files changed, 4 insertions(+), 14 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index fdef32e009a3..d8cd0ca4f945 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -835,11 +835,6 @@ public TSchemaPartitionTableResp getSchemaPartition( return getSchemaPartition(databaseSlotMap); } - @Override - public TSchemaPartitionTableResp getSchemaPartition4TableModel(final String database) { - return getSchemaPartition(Collections.singletonMap(database, Collections.emptyList())); - } - @Override public TSchemaPartitionTableResp getSchemaPartition( final Map> dbSlotMap) { @@ -2418,7 +2413,8 @@ public Map getRelatedSchemaRegionGroup( public Map getRelatedSchemaRegionGroup4TableModel( final String database) { return getRelatedSchemaRegionGroup( - getSchemaPartition4TableModel(database).getSchemaPartitionTable()); + getSchemaPartition(Collections.singletonMap(database, Collections.emptyList())) + .getSchemaPartitionTable()); } private Map getRelatedSchemaRegionGroup( @@ -2450,7 +2446,8 @@ public Map getRelatedDataRegionGroup( public Map getRelatedDataRegionGroup4TableModel( final String database) { return getRelatedDataRegionGroup( - getSchemaPartition4TableModel(database).getSchemaPartitionTable()); + getSchemaPartition(Collections.singletonMap(database, Collections.emptyList())) + .getSchemaPartitionTable()); } private Map getRelatedDataRegionGroup( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java index cae5b6c1633d..526c66612995 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java @@ -424,13 +424,6 @@ public interface IManager { TSchemaPartitionTableResp getSchemaPartition( final PathPatternTree patternTree, final boolean isTableModel); - /** - * Get SchemaPartition. - * - * @return TSchemaPartitionResp - */ - TSchemaPartitionTableResp getSchemaPartition4TableModel(final String database); - /** * Get SchemaPartition with . * From bea025c5d7bb3e4461364150729b05d84232ff8d Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:48:49 +0800 Subject: [PATCH 65/71] Fix --- .../iotdb/confignode/manager/ConfigManager.java | 11 ++++------- .../org/apache/iotdb/confignode/manager/IManager.java | 3 +-- .../impl/schema/AlterLogicalViewProcedure.java | 2 +- .../service/thrift/ConfigNodeRPCServiceProcessor.java | 4 +--- 4 files changed, 7 insertions(+), 13 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index d8cd0ca4f945..4c6515c5fb80 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -791,8 +791,7 @@ private List calculateRelatedSlot( } @Override - public TSchemaPartitionTableResp getSchemaPartition( - final PathPatternTree patternTree, final boolean isTableModel) { + public TSchemaPartitionTableResp getSchemaPartition(final PathPatternTree patternTree) { // Construct empty response final TSStatus status = confirmLeader(); @@ -804,7 +803,7 @@ public TSchemaPartitionTableResp getSchemaPartition( // Build GetSchemaPartitionPlan final Map> partitionSlotsMap = new HashMap<>(); final List relatedPaths = patternTree.getAllPathPatterns(); - final List allDatabases = getClusterSchemaManager().getDatabaseNames(isTableModel); + final List allDatabases = getClusterSchemaManager().getDatabaseNames(false); final List allDatabasePaths = new ArrayList<>(); for (final String database : allDatabases) { try { @@ -2406,8 +2405,7 @@ public TShowCQResp showCQ() { */ public Map getRelatedSchemaRegionGroup( final PathPatternTree patternTree) { - return getRelatedSchemaRegionGroup( - getSchemaPartition(patternTree, false).getSchemaPartitionTable()); + return getRelatedSchemaRegionGroup(getSchemaPartition(patternTree).getSchemaPartitionTable()); } public Map getRelatedSchemaRegionGroup4TableModel( @@ -2439,8 +2437,7 @@ private Map getRelatedSchemaRegionGroup( */ public Map getRelatedDataRegionGroup( final PathPatternTree patternTree) { - return getRelatedDataRegionGroup( - getSchemaPartition(patternTree, false).getSchemaPartitionTable()); + return getRelatedDataRegionGroup(getSchemaPartition(patternTree).getSchemaPartitionTable()); } public Map getRelatedDataRegionGroup4TableModel( diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java index 526c66612995..028dc0e2f638 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java @@ -421,8 +421,7 @@ public interface IManager { * * @return TSchemaPartitionResp */ - TSchemaPartitionTableResp getSchemaPartition( - final PathPatternTree patternTree, final boolean isTableModel); + TSchemaPartitionTableResp getSchemaPartition(final PathPatternTree patternTree); /** * Get SchemaPartition with . diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/AlterLogicalViewProcedure.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/AlterLogicalViewProcedure.java index 7db6c583aaec..b0210944d111 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/AlterLogicalViewProcedure.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/procedure/impl/schema/AlterLogicalViewProcedure.java @@ -193,7 +193,7 @@ private TConsensusGroupId getBelongedSchemaRegion( patternTree.appendFullPath(viewPath); patternTree.constructTree(); final Map> schemaPartitionTable = - env.getConfigManager().getSchemaPartition(patternTree, false).schemaPartitionTable; + env.getConfigManager().getSchemaPartition(patternTree).schemaPartitionTable; if (schemaPartitionTable.isEmpty()) { throw new ProcedureException(new ViewNotExistException(viewPath.getFullPath())); } else { diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 71c3d331ab95..02dc61fdaba2 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -621,10 +621,8 @@ public TSStatus callSpecialProcedure(TTestOperation operation) { @Override public TSchemaPartitionTableResp getSchemaPartitionTable(final TSchemaPartitionReq req) { - final PathPatternTree patternTree = - PathPatternTree.deserialize(ByteBuffer.wrap(req.getPathPatternTree())); return configManager.getSchemaPartition( - patternTree, req.isSetIsTableModel() && req.isIsTableModel()); + PathPatternTree.deserialize(ByteBuffer.wrap(req.getPathPatternTree()))); } @Override From dbb4b701f85826d5dc8bfc19b5d08996578efae3 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:55:38 +0800 Subject: [PATCH 66/71] Fix --- .../queryengine/plan/analyze/ClusterPartitionFetcher.java | 8 ++++---- .../thrift-confignode/src/main/thrift/confignode.thrift | 1 - 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index 76c9945c8385..6f10a0b27725 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -104,7 +104,7 @@ public SchemaPartition getSchemaPartition(final PathPatternTree patternTree) { SchemaPartition schemaPartition = partitionCache.getSchemaPartition(storageGroupToDeviceMap); if (null == schemaPartition) { final TSchemaPartitionTableResp schemaPartitionTableResp = - client.getSchemaPartitionTable(constructSchemaPartitionReq(patternTree, false)); + client.getSchemaPartitionTable(constructSchemaPartitionReq(patternTree)); if (schemaPartitionTableResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { schemaPartition = parseSchemaPartitionTableResp(schemaPartitionTableResp); @@ -136,7 +136,7 @@ public SchemaPartition getOrCreateSchemaPartition( SchemaPartition schemaPartition = partitionCache.getSchemaPartition(storageGroupToDeviceMap); if (null == schemaPartition) { final TSchemaPartitionTableResp schemaPartitionTableResp = - client.getOrCreateSchemaPartitionTable(constructSchemaPartitionReq(patternTree, false)); + client.getOrCreateSchemaPartitionTable(constructSchemaPartitionReq(patternTree)); if (schemaPartitionTableResp.getStatus().getCode() == TSStatusCode.SUCCESS_STATUS.getStatusCode()) { schemaPartition = parseSchemaPartitionTableResp(schemaPartitionTableResp); @@ -380,9 +380,9 @@ private Map> splitDataPartitionQueryParam( } private TSchemaPartitionReq constructSchemaPartitionReq( - final PathPatternTree patternTree, final boolean isTableModel) { + final PathPatternTree patternTree) { try { - return new TSchemaPartitionReq(patternTree.serialize()).setIsTableModel(isTableModel); + return new TSchemaPartitionReq(patternTree.serialize()); } catch (final IOException e) { throw new StatementAnalyzeException("An error occurred when serializing pattern tree"); } diff --git a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift index 97bdccfa8241..5f090003119d 100644 --- a/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift +++ b/iotdb-protocol/thrift-confignode/src/main/thrift/confignode.thrift @@ -217,7 +217,6 @@ struct TDatabaseSchema { // Schema struct TSchemaPartitionReq { 1: required binary pathPatternTree - 2: optional bool isTableModel } struct TSchemaPartitionTableResp { From 0517a3b8940936b94b56ab4f74375ab6aac8a464 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 15:55:41 +0800 Subject: [PATCH 67/71] Update ClusterPartitionFetcher.java --- .../db/queryengine/plan/analyze/ClusterPartitionFetcher.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index 6f10a0b27725..f1272e3c24ba 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -379,8 +379,7 @@ private Map> splitDataPartitionQueryParam( return result; } - private TSchemaPartitionReq constructSchemaPartitionReq( - final PathPatternTree patternTree) { + private TSchemaPartitionReq constructSchemaPartitionReq(final PathPatternTree patternTree) { try { return new TSchemaPartitionReq(patternTree.serialize()); } catch (final IOException e) { From 0724f70578e5fb6278bb788b77e34eeabebe5278 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 16:04:40 +0800 Subject: [PATCH 68/71] Fix --- .../queryengine/plan/analyze/FakePartitionFetcherImpl.java | 5 ----- .../iotdb/db/queryengine/plan/planner/distribution/Util.java | 5 ----- .../db/queryengine/plan/planner/distribution/Util2.java | 5 ----- .../queryengine/plan/relational/analyzer/TSBSMetadata.java | 5 ----- .../queryengine/plan/relational/analyzer/TestMatadata.java | 5 ----- 5 files changed, 25 deletions(-) diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/FakePartitionFetcherImpl.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/FakePartitionFetcherImpl.java index b7e4ac4567f4..338a05b45759 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/FakePartitionFetcherImpl.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/analyze/FakePartitionFetcherImpl.java @@ -311,9 +311,4 @@ public SchemaPartition getOrCreateSchemaPartition( public SchemaPartition getSchemaPartition(String database, List deviceIDList) { return null; } - - @Override - public SchemaPartition getSchemaPartition(String database) { - return null; - } } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util.java index 9f4930eb54d7..8fcc6ae7972c 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util.java @@ -431,11 +431,6 @@ public SchemaPartition getOrCreateSchemaPartition( public SchemaPartition getSchemaPartition(String database, List deviceIDList) { return null; } - - @Override - public SchemaPartition getSchemaPartition(String database) { - return null; - } }; } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util2.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util2.java index 312f257309fa..42e8dc1f2c25 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util2.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/planner/distribution/Util2.java @@ -324,11 +324,6 @@ public SchemaPartition getOrCreateSchemaPartition( public SchemaPartition getSchemaPartition(String database, List deviceIDList) { return null; } - - @Override - public SchemaPartition getSchemaPartition(String database) { - return null; - } }; } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TSBSMetadata.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TSBSMetadata.java index 2747a9e752a0..a34129a73f88 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TSBSMetadata.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TSBSMetadata.java @@ -451,11 +451,6 @@ public SchemaPartition getOrCreateSchemaPartition( public SchemaPartition getSchemaPartition(String database, List deviceIDList) { return SCHEMA_PARTITION; } - - @Override - public SchemaPartition getSchemaPartition(String database) { - return SCHEMA_PARTITION; - } }; } } diff --git a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java index b07c4a0b1fe3..99d97626c9b2 100644 --- a/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java +++ b/iotdb-core/datanode/src/test/java/org/apache/iotdb/db/queryengine/plan/relational/analyzer/TestMatadata.java @@ -447,11 +447,6 @@ public SchemaPartition getOrCreateSchemaPartition( public SchemaPartition getSchemaPartition(String database, List deviceIDList) { return SCHEMA_PARTITION; } - - @Override - public SchemaPartition getSchemaPartition(String database) { - return SCHEMA_PARTITION; - } }; } } From 10a62c3c114646fb2701a8077da0da6ae2ec204d Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 16:15:45 +0800 Subject: [PATCH 69/71] Fix --- .../org/apache/iotdb/confignode/manager/ConfigManager.java | 5 ++--- .../java/org/apache/iotdb/confignode/manager/IManager.java | 3 +-- .../service/thrift/ConfigNodeRPCServiceProcessor.java | 4 +--- 3 files changed, 4 insertions(+), 8 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java index 4c6515c5fb80..671aca0e17b9 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/ConfigManager.java @@ -858,8 +858,7 @@ public TSchemaPartitionTableResp getSchemaPartition( } @Override - public TSchemaPartitionTableResp getOrCreateSchemaPartition( - final PathPatternTree patternTree, final boolean isTableModel) { + public TSchemaPartitionTableResp getOrCreateSchemaPartition(final PathPatternTree patternTree) { final TSStatus status = confirmLeader(); if (status.getCode() != TSStatusCode.SUCCESS_STATUS.getStatusCode()) { // Construct empty response @@ -868,7 +867,7 @@ public TSchemaPartitionTableResp getOrCreateSchemaPartition( } final List devicePaths = patternTree.getAllDevicePatterns(); - final List databases = getClusterSchemaManager().getDatabaseNames(isTableModel); + final List databases = getClusterSchemaManager().getDatabaseNames(false); // Build GetOrCreateSchemaPartitionPlan final Map> partitionSlotsMap = new HashMap<>(); diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java index 028dc0e2f638..779f3daa03b8 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/IManager.java @@ -435,8 +435,7 @@ public interface IManager { * * @return TSchemaPartitionResp */ - TSchemaPartitionTableResp getOrCreateSchemaPartition( - final PathPatternTree patternTree, final boolean isTableModel); + TSchemaPartitionTableResp getOrCreateSchemaPartition(final PathPatternTree patternTree); /** * Get or create SchemaPartition with . diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 02dc61fdaba2..9e564ead8a59 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -633,10 +633,8 @@ public TSchemaPartitionTableResp getSchemaPartitionTableWithSlots( @Override public TSchemaPartitionTableResp getOrCreateSchemaPartitionTable(final TSchemaPartitionReq req) { - final PathPatternTree patternTree = - PathPatternTree.deserialize(ByteBuffer.wrap(req.getPathPatternTree())); return configManager.getOrCreateSchemaPartition( - patternTree, req.isSetIsTableModel() && req.isIsTableModel()); + PathPatternTree.deserialize(ByteBuffer.wrap(req.getPathPatternTree()))); } @Override From 1989202e657d420b32d0d8afa39a799fd3e140f7 Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 16:40:27 +0800 Subject: [PATCH 70/71] Fix --- .../thrift/ConfigNodeRPCServiceProcessor.java | 2 +- .../plan/analyze/ClusterPartitionFetcher.java | 24 +++++++++++++------ .../plan/analyze/IPartitionFetcher.java | 3 ++- .../metadata/TableMetadataImpl.java | 2 +- 4 files changed, 21 insertions(+), 10 deletions(-) diff --git a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java index 9e564ead8a59..ecfe6455d4b4 100644 --- a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java +++ b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/service/thrift/ConfigNodeRPCServiceProcessor.java @@ -639,7 +639,7 @@ public TSchemaPartitionTableResp getOrCreateSchemaPartitionTable(final TSchemaPa @Override public TSchemaPartitionTableResp getOrCreateSchemaPartitionTableWithSlots( - Map> dbSlotMap) { + final Map> dbSlotMap) { return configManager.getOrCreateSchemaPartition(dbSlotMap); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java index f1272e3c24ba..d08d4ca013b9 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/ClusterPartitionFetcher.java @@ -53,6 +53,8 @@ import org.apache.thrift.TException; import org.apache.tsfile.file.metadata.IDeviceID; +import javax.annotation.Nullable; + import java.io.IOException; import java.util.ArrayList; import java.util.Collections; @@ -61,6 +63,7 @@ import java.util.LinkedList; import java.util.List; import java.util.Map; +import java.util.Objects; import java.util.Set; import java.util.stream.Collectors; @@ -300,28 +303,34 @@ public SchemaPartition getOrCreateSchemaPartition( return getOrCreateSchemaPartition(database, deviceIDs, true, userName); } + // deviceIDs is null if search the whole database, in which case we skip the cache and fetch the + // configNode directly @Override public SchemaPartition getSchemaPartition( - final String database, final List deviceIDs) { + final String database, final @Nullable List deviceIDs) { return getOrCreateSchemaPartition(database, deviceIDs, false, null); } private SchemaPartition getOrCreateSchemaPartition( final String database, - final List deviceIDs, + final @Nullable List deviceIDs, final boolean isAutoCreate, final String userName) { try (final ConfigNodeClient client = configNodeClientManager.borrowClient(ConfigNodeInfo.CONFIG_REGION_ID)) { partitionCache.checkAndAutoCreateDatabase(database, isAutoCreate, userName); SchemaPartition schemaPartition = - partitionCache.getSchemaPartition(Collections.singletonMap(database, deviceIDs)); + Objects.nonNull(deviceIDs) + ? partitionCache.getSchemaPartition(Collections.singletonMap(database, deviceIDs)) + : null; if (null == schemaPartition) { final List partitionSlots = - deviceIDs.stream() - .map(partitionExecutor::getSeriesPartitionSlot) - .distinct() - .collect(Collectors.toList()); + Objects.nonNull(deviceIDs) + ? deviceIDs.stream() + .map(partitionExecutor::getSeriesPartitionSlot) + .distinct() + .collect(Collectors.toList()) + : Collections.emptyList(); final TSchemaPartitionTableResp schemaPartitionTableResp = isAutoCreate ? client.getOrCreateSchemaPartitionTableWithSlots( @@ -340,6 +349,7 @@ private SchemaPartition getOrCreateSchemaPartition( schemaPartitionTableResp.getStatus().getCode())); } } + System.out.println(schemaPartition.getSchemaPartitionMap()); return schemaPartition; } catch (final ClientManagerException | TException e) { throw new StatementAnalyzeException( diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java index 43cf93dc291f..f21eaa943f32 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java @@ -28,6 +28,7 @@ import org.apache.tsfile.file.metadata.IDeviceID; +import javax.annotation.Nullable; import java.util.List; import java.util.Map; @@ -113,5 +114,5 @@ SchemaPartition getOrCreateSchemaPartition( * *

The device id shall be [table, seg1, ....] */ - SchemaPartition getSchemaPartition(final String database, final List deviceIDs); + SchemaPartition getSchemaPartition(final String database, final @Nullable List deviceIDs); } diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java index b705e7739d26..289d20598ec7 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/relational/metadata/TableMetadataImpl.java @@ -739,7 +739,7 @@ public SchemaPartition getSchemaPartition( @Override public SchemaPartition getSchemaPartition(final String database) { - return partitionFetcher.getSchemaPartition(database, Collections.emptyList()); + return partitionFetcher.getSchemaPartition(database, null); } @Override From 26e03891f8cb5bf036914b1bc4ec36cd3355dd2e Mon Sep 17 00:00:00 2001 From: Caideyipi <87789683+Caideyipi@users.noreply.github.com> Date: Tue, 17 Dec 2024 16:42:09 +0800 Subject: [PATCH 71/71] Update IPartitionFetcher.java --- .../iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java index f21eaa943f32..75a59bd43594 100644 --- a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java +++ b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/queryengine/plan/analyze/IPartitionFetcher.java @@ -29,6 +29,7 @@ import org.apache.tsfile.file.metadata.IDeviceID; import javax.annotation.Nullable; + import java.util.List; import java.util.Map; @@ -114,5 +115,6 @@ SchemaPartition getOrCreateSchemaPartition( * *

The device id shall be [table, seg1, ....] */ - SchemaPartition getSchemaPartition(final String database, final @Nullable List deviceIDs); + SchemaPartition getSchemaPartition( + final String database, final @Nullable List deviceIDs); }