Skip to content

Commit

Permalink
Refactor MetaDataRefreshEngine (apache#32467)
Browse files Browse the repository at this point in the history
  • Loading branch information
terrymanu authored Aug 11, 2024
1 parent fbf9305 commit 4d448e5
Showing 1 changed file with 11 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@
import org.apache.shardingsphere.infra.route.context.RouteUnit;
import org.apache.shardingsphere.infra.spi.type.typed.TypedSPILoader;
import org.apache.shardingsphere.mode.persist.service.MetaDataManagerPersistService;
import org.apache.shardingsphere.sql.parser.statement.core.statement.SQLStatement;
import org.apache.shardingsphere.sql.parser.statement.core.statement.ddl.AlterIndexStatement;
import org.apache.shardingsphere.sql.parser.statement.core.statement.ddl.AlterSchemaStatement;
import org.apache.shardingsphere.sql.parser.statement.core.statement.ddl.AlterTableStatement;
Expand Down Expand Up @@ -79,14 +78,10 @@ public void refresh(final SQLStatementContext sqlStatementContext, final Collect
}
Optional<MetaDataRefresher> schemaRefresher = TypedSPILoader.findService(MetaDataRefresher.class, sqlStatementClass);
if (schemaRefresher.isPresent()) {
String schemaName = null;
if (sqlStatementContext instanceof TableAvailable) {
schemaName = ((TableAvailable) sqlStatementContext).getTablesContext().getSchemaName()
.orElseGet(() -> new DatabaseTypeRegistry(sqlStatementContext.getDatabaseType()).getDefaultSchemaName(database.getName())).toLowerCase();
}
Collection<String> logicDataSourceNames = routeUnits.stream().map(each -> each.getDataSourceMapper().getLogicName()).collect(Collectors.toList());
schemaRefresher.get().refresh(metaDataManagerPersistService, database,
logicDataSourceNames, schemaName, sqlStatementContext.getDatabaseType(), sqlStatementContext.getSqlStatement(), props);
String schemaName = sqlStatementContext instanceof TableAvailable ? getSchemaName(sqlStatementContext) : null;
schemaRefresher.get().refresh(
metaDataManagerPersistService, database, logicDataSourceNames, schemaName, sqlStatementContext.getDatabaseType(), sqlStatementContext.getSqlStatement(), props);
}
}

Expand All @@ -97,11 +92,13 @@ public void refresh(final SQLStatementContext sqlStatementContext, final Collect
*/
@SuppressWarnings("unchecked")
public void refresh(final SQLStatementContext sqlStatementContext) {
getFederationMetaDataRefresher(sqlStatementContext).ifPresent(federationMetaDataRefresher -> {
String schemaName = ((TableAvailable) sqlStatementContext).getTablesContext().getSchemaName()
.orElseGet(() -> new DatabaseTypeRegistry(sqlStatementContext.getDatabaseType()).getDefaultSchemaName(database.getName())).toLowerCase();
federationMetaDataRefresher.refresh(metaDataManagerPersistService, database, schemaName, sqlStatementContext.getDatabaseType(), sqlStatementContext.getSqlStatement());
});
getFederationMetaDataRefresher(sqlStatementContext).ifPresent(optional -> optional.refresh(
metaDataManagerPersistService, database, getSchemaName(sqlStatementContext), sqlStatementContext.getDatabaseType(), sqlStatementContext.getSqlStatement()));
}

private String getSchemaName(final SQLStatementContext sqlStatementContext) {
return ((TableAvailable) sqlStatementContext).getTablesContext().getSchemaName()
.orElseGet(() -> new DatabaseTypeRegistry(sqlStatementContext.getDatabaseType()).getDefaultSchemaName(database.getName())).toLowerCase();
}

/**
Expand All @@ -116,7 +113,6 @@ public boolean isFederation(final SQLStatementContext sqlStatementContext) {

@SuppressWarnings("rawtypes")
private Optional<FederationMetaDataRefresher> getFederationMetaDataRefresher(final SQLStatementContext sqlStatementContext) {
Class<? extends SQLStatement> sqlStatementClass = sqlStatementContext.getSqlStatement().getClass();
return TypedSPILoader.findService(FederationMetaDataRefresher.class, sqlStatementClass.getSuperclass());
return TypedSPILoader.findService(FederationMetaDataRefresher.class, sqlStatementContext.getSqlStatement().getClass().getSuperclass());
}
}

0 comments on commit 4d448e5

Please sign in to comment.