Skip to content

Commit

Permalink
storage: Fix TiFlash system tables cannot query in Keyspace Mode (pin…
Browse files Browse the repository at this point in the history
…gcap#209)

Signed-off-by: Wish <breezewish@outlook.com>
  • Loading branch information
breezewish authored and Lloyd-Pottiger committed Aug 26, 2024
1 parent bfb8c5d commit 06ebbe2
Showing 1 changed file with 12 additions and 5 deletions.
17 changes: 12 additions & 5 deletions dbms/src/Interpreters/InterpreterSelectQuery.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -224,13 +224,19 @@ void InterpreterSelectQuery::getAndLockStorageWithSchemaVersion(const String & d
// always sync schema first and then read table
const String qualified_name = database_name + "." + table_name;

bool need_sync_schema = true;
if (database_name == "system")
need_sync_schema = false;
else if (database_name.empty() && context.getCurrentDatabase() == "system")
need_sync_schema = false;

{
auto start_time = Clock::now();
// Since InterpreterSelectQuery will only be trigger while using ClickHouse client,
// and we do not support keyspace feature for ClickHouse interface,
// we could use nullspace id here safely.
context.getTMTContext().getSchemaSyncerManager()->syncSchemas(context, NullspaceID);
if (need_sync_schema)
context.getTMTContext().getSchemaSyncerManager()->syncSchemas(context, NullspaceID);
auto storage_tmp = context.getTable(database_name, table_name);
auto managed_storage = std::dynamic_pointer_cast<IManageableStorage>(storage_tmp);
if (!managed_storage
Expand All @@ -243,10 +249,11 @@ void InterpreterSelectQuery::getAndLockStorageWithSchemaVersion(const String & d
return;
}

context.getTMTContext().getSchemaSyncerManager()->syncTableSchema(
context,
NullspaceID,
managed_storage->getTableInfo().id);
if (need_sync_schema)
context.getTMTContext().getSchemaSyncerManager()->syncTableSchema(
context,
NullspaceID,
managed_storage->getTableInfo().id);
auto schema_sync_cost
= std::chrono::duration_cast<std::chrono::milliseconds>(Clock::now() - start_time).count();
LOG_DEBUG(log, "Table {} schema sync cost {}ms.", qualified_name, schema_sync_cost);
Expand Down

0 comments on commit 06ebbe2

Please sign in to comment.