mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 18:32:29 +00:00
merge_row_policy: style fixes and back to storage->read
This commit is contained in:
parent
657c39c79e
commit
359cd4d32a
@ -1529,7 +1529,7 @@ void InterpreterSelectQuery::executeImpl(QueryPlan & query_plan, std::optional<P
|
|||||||
// Thus, we don't actually need to check if projection is active.
|
// Thus, we don't actually need to check if projection is active.
|
||||||
if (!query_info.projection && expressions.filter_info)
|
if (!query_info.projection && expressions.filter_info)
|
||||||
{
|
{
|
||||||
LOG_TRACE(log, "executeImpl, adding Row-level security filter; column_name {}, block {}",
|
LOG_TRACE(log, "executeImpl, adding Row-level security filter; column_name {}, block {}",
|
||||||
expressions.filter_info->column_name, query_plan.getCurrentDataStream().header.dumpStructure());
|
expressions.filter_info->column_name, query_plan.getCurrentDataStream().header.dumpStructure());
|
||||||
|
|
||||||
auto row_level_security_step = std::make_unique<FilterStep>(
|
auto row_level_security_step = std::make_unique<FilterStep>(
|
||||||
|
@ -369,7 +369,7 @@ void StorageMerge::read(
|
|||||||
|
|
||||||
/// What will be result structure depending on query processed stage in source tables?
|
/// What will be result structure depending on query processed stage in source tables?
|
||||||
// Block common_header = getHeaderForProcessingStage(column_names, storage_snapshot, query_info, local_context, QueryProcessingStage::Complete /* processed_stage */);
|
// Block common_header = getHeaderForProcessingStage(column_names, storage_snapshot, query_info, local_context, QueryProcessingStage::Complete /* processed_stage */);
|
||||||
Block common_header = getHeaderForProcessingStage(column_names, storage_snapshot, query_info, local_context, processed_stage );
|
Block common_header = getHeaderForProcessingStage(column_names, storage_snapshot, query_info, local_context, processed_stage);
|
||||||
|
|
||||||
auto step = std::make_unique<ReadFromMerge>(
|
auto step = std::make_unique<ReadFromMerge>(
|
||||||
common_header,
|
common_header,
|
||||||
@ -677,7 +677,7 @@ QueryPipelineBuilderPtr ReadFromMerge::createSources(
|
|||||||
QueryPlan & plan = child_plans.emplace_back();
|
QueryPlan & plan = child_plans.emplace_back();
|
||||||
|
|
||||||
StorageView * view = dynamic_cast<StorageView *>(storage.get());
|
StorageView * view = dynamic_cast<StorageView *>(storage.get());
|
||||||
if (/* !view || */ allow_experimental_analyzer)
|
if ( !view || allow_experimental_analyzer)
|
||||||
// if (!view || allow_experimental_analyzer)
|
// if (!view || allow_experimental_analyzer)
|
||||||
{
|
{
|
||||||
LOG_TRACE(&Poco::Logger::get("ReadFromMerge::createSources"), "direct storage->read");
|
LOG_TRACE(&Poco::Logger::get("ReadFromMerge::createSources"), "direct storage->read");
|
||||||
@ -690,26 +690,26 @@ QueryPipelineBuilderPtr ReadFromMerge::createSources(
|
|||||||
max_block_size,
|
max_block_size,
|
||||||
UInt32(streams_num));
|
UInt32(streams_num));
|
||||||
}
|
}
|
||||||
else if (!view)
|
// else if (!view)
|
||||||
{
|
// {
|
||||||
/// For view storage, we need to rewrite the `modified_query_info.view_query` to optimize read.
|
// /// For view storage, we need to rewrite the `modified_query_info.view_query` to optimize read.
|
||||||
/// The most intuitive way is to use InterpreterSelectQuery.
|
// /// The most intuitive way is to use InterpreterSelectQuery.
|
||||||
|
|
||||||
/// Intercept the settings
|
// /// Intercept the settings
|
||||||
modified_context->setSetting("max_threads", streams_num);
|
// modified_context->setSetting("max_threads", streams_num);
|
||||||
modified_context->setSetting("max_streams_to_max_threads_ratio", 1);
|
// modified_context->setSetting("max_streams_to_max_threads_ratio", 1);
|
||||||
modified_context->setSetting("max_block_size", max_block_size);
|
// modified_context->setSetting("max_block_size", max_block_size);
|
||||||
|
|
||||||
LOG_TRACE(&Poco::Logger::get("ReadFromMerge::createSources"), "creating InterpreterSelectQuery 1.0");
|
// LOG_TRACE(&Poco::Logger::get("ReadFromMerge::createSources"), "creating InterpreterSelectQuery 1.0");
|
||||||
InterpreterSelectQuery interpreter(modified_query_info.query,
|
// InterpreterSelectQuery interpreter(modified_query_info.query,
|
||||||
modified_context,
|
// modified_context,
|
||||||
storage,
|
// storage,
|
||||||
storage->getInMemoryMetadataPtr(), // view->getInMemoryMetadataPtr(),
|
// storage->getInMemoryMetadataPtr(), // view->getInMemoryMetadataPtr(),
|
||||||
// SelectQueryOptions(/* processed_stage*/));
|
// // SelectQueryOptions(/* processed_stage*/));
|
||||||
SelectQueryOptions(processed_stage));
|
// SelectQueryOptions(processed_stage));
|
||||||
// SelectQueryOptions(QueryProcessingStage::WithMergeableState));
|
// // SelectQueryOptions(QueryProcessingStage::WithMergeableState));
|
||||||
interpreter.buildQueryPlan(plan);
|
// interpreter.buildQueryPlan(plan);
|
||||||
}
|
// }
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/// For view storage, we need to rewrite the `modified_query_info.view_query` to optimize read.
|
/// For view storage, we need to rewrite the `modified_query_info.view_query` to optimize read.
|
||||||
|
Loading…
Reference in New Issue
Block a user