diff --git a/proxy/backend/core/src/main/java/org/apache/shardingsphere/proxy/backend/handler/distsql/rql/storage/unit/ShowStorageUnitExecutor.java b/proxy/backend/core/src/main/java/org/apache/shardingsphere/proxy/backend/handler/distsql/rql/storage/unit/ShowStorageUnitExecutor.java index 25604d8d3db42..13ea8dcc689c6 100644 --- a/proxy/backend/core/src/main/java/org/apache/shardingsphere/proxy/backend/handler/distsql/rql/storage/unit/ShowStorageUnitExecutor.java +++ b/proxy/backend/core/src/main/java/org/apache/shardingsphere/proxy/backend/handler/distsql/rql/storage/unit/ShowStorageUnitExecutor.java @@ -20,7 +20,6 @@ import org.apache.shardingsphere.distsql.handler.query.RQLExecutor; import org.apache.shardingsphere.distsql.parser.statement.rql.show.ShowStorageUnitsStatement; import org.apache.shardingsphere.infra.database.core.connector.ConnectionProperties; -import org.apache.shardingsphere.infra.database.core.metadata.database.DialectDatabaseMetaData; import org.apache.shardingsphere.infra.database.core.type.DatabaseType; import org.apache.shardingsphere.infra.database.core.type.DatabaseTypeRegistry; import org.apache.shardingsphere.infra.datasource.pool.CatalogSwitchableDataSource; @@ -28,7 +27,6 @@ import org.apache.shardingsphere.infra.datasource.pool.props.domain.DataSourcePoolProperties; import org.apache.shardingsphere.infra.merge.result.impl.local.LocalDataQueryResultRow; import org.apache.shardingsphere.infra.metadata.database.ShardingSphereDatabase; -import org.apache.shardingsphere.infra.metadata.database.resource.ResourceMetaData; import org.apache.shardingsphere.infra.metadata.database.resource.unit.StorageUnit; import org.apache.shardingsphere.infra.rule.ShardingSphereRule; import org.apache.shardingsphere.infra.util.json.JsonUtils; @@ -57,15 +55,15 @@ public Collection getColumnNames() { @Override public Collection getRows(final ShardingSphereDatabase database, final ShowStorageUnitsStatement sqlStatement) { - ResourceMetaData resourceMetaData = database.getResourceMetaData(); Collection result = new LinkedList<>(); for (Entry entry : getDataSourcePoolPropertiesMap(database, sqlStatement).entrySet()) { - String key = entry.getKey(); - ConnectionProperties connectionProps = resourceMetaData.getStorageUnits().get(key).getConnectionProperties(); + String storageUnitName = entry.getKey(); + StorageUnit storageUnit = database.getResourceMetaData().getStorageUnits().get(storageUnitName); + ConnectionProperties connectionProps = storageUnit.getConnectionProperties(); Map poolProps = entry.getValue().getPoolPropertySynonyms().getStandardProperties(); - Map customProps = getCustomProps(entry.getValue().getCustomProperties().getProperties(), connectionProps.getQueryProperties()); - result.add(new LocalDataQueryResultRow(key, - resourceMetaData.getStorageUnits().get(key).getStorageType().getType(), + Map customProps = getCustomProperties(entry.getValue().getCustomProperties().getProperties(), connectionProps.getQueryProperties()); + result.add(new LocalDataQueryResultRow(storageUnitName, + storageUnit.getStorageType().getType(), connectionProps.getHostname(), connectionProps.getPort(), connectionProps.getCatalog(), @@ -80,15 +78,6 @@ public Collection getRows(final ShardingSphereDatabase return result; } - private Map getCustomProps(final Map customProps, final Properties queryProps) { - Map result = new LinkedHashMap<>(customProps.size() + 1, 1F); - result.putAll(customProps); - if (!queryProps.isEmpty()) { - result.put("queryProperties", queryProps); - } - return result; - } - private Map getDataSourcePoolPropertiesMap(final ShardingSphereDatabase database, final ShowStorageUnitsStatement sqlStatement) { Map result = new LinkedHashMap<>(database.getResourceMetaData().getStorageUnits().size(), 1F); Map propsMap = database.getResourceMetaData().getStorageUnits().entrySet().stream() @@ -113,11 +102,10 @@ private Map getDataSourcePoolPropertiesMap(fin private DataSourcePoolProperties getDataSourcePoolProperties(final Map propsMap, final String storageUnitName, final DatabaseType databaseType, final DataSource dataSource) { - DataSourcePoolProperties result = getDataSourcePoolProperties(dataSource); - DialectDatabaseMetaData dialectDatabaseMetaData = new DatabaseTypeRegistry(databaseType).getDialectDatabaseMetaData(); - if (dialectDatabaseMetaData.isInstanceConnectionAvailable() && propsMap.containsKey(storageUnitName)) { - DataSourcePoolProperties unitDataSourcePoolProps = propsMap.get(storageUnitName); - for (Entry entry : unitDataSourcePoolProps.getPoolPropertySynonyms().getStandardProperties().entrySet()) { + DataSourcePoolProperties result = DataSourcePoolPropertiesCreator.create( + dataSource instanceof CatalogSwitchableDataSource ? ((CatalogSwitchableDataSource) dataSource).getDataSource() : dataSource); + if (new DatabaseTypeRegistry(databaseType).getDialectDatabaseMetaData().isInstanceConnectionAvailable() && propsMap.containsKey(storageUnitName)) { + for (Entry entry : propsMap.get(storageUnitName).getPoolPropertySynonyms().getStandardProperties().entrySet()) { if (null != entry.getValue()) { result.getPoolPropertySynonyms().getStandardProperties().put(entry.getKey(), entry.getValue()); } @@ -126,10 +114,12 @@ private DataSourcePoolProperties getDataSourcePoolProperties(final Map getCustomProperties(final Map customProps, final Properties queryProps) { + Map result = new LinkedHashMap<>(customProps); + if (!queryProps.isEmpty()) { + result.put("queryProperties", queryProps); + } + return result; } private String getStandardProperty(final Map standardProps, final String key) {