be/src/exec/operator/scan_operator.cpp
Line | Count | Source |
1 | | // Licensed to the Apache Software Foundation (ASF) under one |
2 | | // or more contributor license agreements. See the NOTICE file |
3 | | // distributed with this work for additional information |
4 | | // regarding copyright ownership. The ASF licenses this file |
5 | | // to you under the Apache License, Version 2.0 (the |
6 | | // "License"); you may not use this file except in compliance |
7 | | // with the License. You may obtain a copy of the License at |
8 | | // |
9 | | // http://www.apache.org/licenses/LICENSE-2.0 |
10 | | // |
11 | | // Unless required by applicable law or agreed to in writing, |
12 | | // software distributed under the License is distributed on an |
13 | | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
14 | | // KIND, either express or implied. See the License for the |
15 | | // specific language governing permissions and limitations |
16 | | // under the License. |
17 | | |
18 | | #include "exec/operator/scan_operator.h" |
19 | | |
20 | | #include <fmt/format.h> |
21 | | #include <gen_cpp/Exprs_types.h> |
22 | | #include <gen_cpp/Metrics_types.h> |
23 | | |
24 | | #include <cstdint> |
25 | | #include <memory> |
26 | | |
27 | | #include "common/global_types.h" |
28 | | #include "core/data_type/data_type.h" |
29 | | #include "core/data_type/data_type_array.h" |
30 | | #include "exec/operator/file_scan_operator.h" |
31 | | #include "exec/operator/group_commit_scan_operator.h" |
32 | | #include "exec/operator/jdbc_scan_operator.h" |
33 | | #include "exec/operator/meta_scan_operator.h" |
34 | | #include "exec/operator/mock_scan_operator.h" |
35 | | #include "exec/operator/olap_scan_operator.h" |
36 | | #include "exec/operator/operator.h" |
37 | | #include "exec/runtime_filter/runtime_filter_consumer_helper.h" |
38 | | #include "exec/scan/scanner_context.h" |
39 | | #include "exprs/function/in.h" |
40 | | #include "exprs/runtime_filter_expr.h" |
41 | | #include "exprs/vcast_expr.h" |
42 | | #include "exprs/vectorized_fn_call.h" |
43 | | #include "exprs/vexpr.h" |
44 | | #include "exprs/vexpr_context.h" |
45 | | #include "exprs/vexpr_fwd.h" |
46 | | #include "exprs/vin_predicate.h" |
47 | | #include "exprs/virtual_slot_ref.h" |
48 | | #include "exprs/vslot_ref.h" |
49 | | #include "exprs/vtopn_pred.h" |
50 | | #include "runtime/descriptors.h" |
51 | | #include "runtime/runtime_profile.h" |
52 | | #include "runtime/runtime_profile_counter_names.h" |
53 | | #include "storage/predicate/null_predicate.h" |
54 | | #include "storage/predicate/predicate_creator.h" |
55 | | |
56 | | namespace doris { |
57 | | |
58 | | #define RETURN_IF_PUSH_DOWN(stmt, status) \ |
59 | 99 | if (pdt == PushDownType::UNACCEPTABLE) { \ |
60 | 99 | status = stmt; \ |
61 | 99 | if (!status.ok()) { \ |
62 | 0 | return; \ |
63 | 0 | } \ |
64 | 99 | } else { \ |
65 | 0 | return; \ |
66 | 0 | } |
67 | | |
68 | | template <typename Derived> |
69 | 21 | bool ScanLocalState<Derived>::should_run_serial() const { |
70 | 21 | return _parent->cast<typename Derived::Parent>()._should_run_serial; |
71 | 21 | } _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE17should_run_serialEv Line | Count | Source | 69 | 18 | bool ScanLocalState<Derived>::should_run_serial() const { | 70 | 18 | return _parent->cast<typename Derived::Parent>()._should_run_serial; | 71 | 18 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17should_run_serialEv _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE17should_run_serialEv Line | Count | Source | 69 | 3 | bool ScanLocalState<Derived>::should_run_serial() const { | 70 | 3 | return _parent->cast<typename Derived::Parent>()._should_run_serial; | 71 | 3 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE17should_run_serialEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17should_run_serialEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE17should_run_serialEv |
72 | | |
73 | | Status ScanLocalStateBase::update_late_arrival_runtime_filter(RuntimeState* state, |
74 | 1 | int& arrived_rf_num) { |
75 | | // Lock needed because _conjuncts can be accessed concurrently by multiple scanner threads |
76 | 1 | LockGuard lock(_conjuncts_lock); |
77 | 1 | size_t conjuncts_before = _conjuncts.size(); |
78 | 1 | RETURN_IF_ERROR(_helper.try_append_late_arrival_runtime_filter(state, _parent->row_descriptor(), |
79 | 1 | arrived_rf_num, _conjuncts)); |
80 | 1 | if (state->enable_adjust_conjunct_order_by_cost()) { |
81 | 0 | std::ranges::sort(_conjuncts, [](const auto& a, const auto& b) { |
82 | 0 | return a->execute_cost() < b->execute_cost(); |
83 | 0 | }); |
84 | 0 | }; |
85 | | // Only re-run partition pruning when try_append_late_arrival_runtime_filter |
86 | | // actually appended new conjuncts. Otherwise this hook would re-scan all |
87 | | // partition boundaries on every scheduler pass while there are still |
88 | | // unapplied RFs (Scanner::_applied_rf_num is not advanced here), wasting |
89 | | // CPU re-evaluating the same set of RFs against the same boundaries. |
90 | 1 | if (_conjuncts.size() > conjuncts_before) { |
91 | 0 | RETURN_IF_ERROR(_on_runtime_filter_update()); |
92 | 0 | } |
93 | 1 | return Status::OK(); |
94 | 1 | } |
95 | | |
96 | 1 | Status ScanLocalStateBase::clone_conjunct_ctxs(VExprContextSPtrs& scanner_conjuncts) { |
97 | | // Lock needed because _conjuncts can be accessed concurrently by multiple scanner threads |
98 | 1 | LockGuard lock(_conjuncts_lock); |
99 | 1 | scanner_conjuncts.resize(_conjuncts.size()); |
100 | 1 | for (size_t i = 0; i != _conjuncts.size(); ++i) { |
101 | 0 | RETURN_IF_ERROR(_conjuncts[i]->clone(_state, scanner_conjuncts[i])); |
102 | 0 | } |
103 | 1 | return Status::OK(); |
104 | 1 | } |
105 | | |
106 | 0 | bool ScanLocalStateBase::is_partition_pruned(int64_t partition_id) const { |
107 | 0 | return _rf_partition_pruner.is_partition_pruned(partition_id); |
108 | 0 | } |
109 | | |
110 | 0 | Status ScanLocalStateBase::_on_runtime_filter_update() { |
111 | 0 | const auto* parsed = _parent->parsed_partition_boundaries(); |
112 | 0 | if (parsed != nullptr && !parsed->empty()) { |
113 | 0 | RETURN_IF_ERROR(_do_partition_pruning_by_rf()); |
114 | 0 | } |
115 | 0 | return Status::OK(); |
116 | 0 | } |
117 | | |
118 | 0 | Status ScanLocalStateBase::_do_partition_pruning_by_rf() { |
119 | 0 | if (!_state->query_options().enable_runtime_filter_partition_prune) { |
120 | 0 | return Status::OK(); |
121 | 0 | } |
122 | 0 | const auto* parsed = _parent->parsed_partition_boundaries(); |
123 | 0 | if (parsed == nullptr || parsed->empty()) { |
124 | 0 | return Status::OK(); |
125 | 0 | } |
126 | 0 | int64_t newly_pruned = 0; |
127 | 0 | RETURN_IF_ERROR(_rf_partition_pruner.prune_by_runtime_filters( |
128 | 0 | *parsed, _conjuncts, _parent->runtime_filter_descs(), _parent->node_id(), |
129 | 0 | &newly_pruned)); |
130 | 0 | if (newly_pruned > 0) { |
131 | 0 | COUNTER_SET(_partitions_pruned_by_rf_counter, |
132 | 0 | _rf_partition_pruner.pruned_partition_count()); |
133 | 0 | } |
134 | 0 | return Status::OK(); |
135 | 0 | } |
136 | | |
137 | 0 | int ScanLocalStateBase::max_scanners_concurrency(RuntimeState* state) const { |
138 | | // For select * from table limit 10; should just use one thread. |
139 | 0 | if (should_run_serial()) { |
140 | 0 | return 1; |
141 | 0 | } |
142 | | /* |
143 | | * The max concurrency of scanners for each ScanLocalStateBase is determined by: |
144 | | * 1. User specified max_scanners_concurrency which is set through session variable. |
145 | | * 2. Default: 4 |
146 | | * |
147 | | * If this is a serial operator, the max concurrency should multiply by the number of parallel instances of the operator. |
148 | | */ |
149 | 0 | return (state->max_scanners_concurrency() > 0 ? state->max_scanners_concurrency() : 4) * |
150 | 0 | (state->query_parallel_instance_num() / _parent->parallelism(state)); |
151 | 0 | } |
152 | | |
153 | 18 | int ScanLocalStateBase::min_scanners_concurrency(RuntimeState* state) const { |
154 | 18 | if (should_run_serial()) { |
155 | 0 | return 1; |
156 | 0 | } |
157 | | /* |
158 | | * The min concurrency of scanners for each ScanLocalStateBase is determined by: |
159 | | * 1. User specified min_scanners_concurrency which is set through session variable. |
160 | | * 2. Default: 1 |
161 | | * |
162 | | * If this is a serial operator, the max concurrency should multiply by the number of parallel instances of the operator. |
163 | | */ |
164 | 18 | return (state->min_scanners_concurrency() > 0 ? state->min_scanners_concurrency() : 1) * |
165 | 18 | (state->query_parallel_instance_num() / _parent->parallelism(state)); |
166 | 18 | } |
167 | | |
168 | 0 | ScannerScheduler* ScanLocalStateBase::scan_scheduler(RuntimeState* state) const { |
169 | 0 | return state->get_query_ctx()->get_scan_scheduler(); |
170 | 0 | } |
171 | | |
172 | | template <typename Derived> |
173 | 4 | Status ScanLocalState<Derived>::init(RuntimeState* state, LocalStateInfo& info) { |
174 | 4 | RETURN_IF_ERROR(PipelineXLocalState<>::init(state, info)); |
175 | 4 | _scan_dependency = Dependency::create_shared(_parent->operator_id(), _parent->node_id(), |
176 | 4 | _parent->get_name() + "_DEPENDENCY"); |
177 | 4 | _wait_for_dependency_timer = ADD_TIMER_WITH_LEVEL( |
178 | 4 | common_profile(), "WaitForDependency[" + _scan_dependency->name() + "]Time", 1); |
179 | 4 | SCOPED_TIMER(exec_time_counter()); |
180 | 4 | SCOPED_TIMER(_init_timer); |
181 | 4 | auto& p = _parent->cast<typename Derived::Parent>(); |
182 | 4 | _max_pushdown_conditions_per_column = p._max_pushdown_conditions_per_column; |
183 | 4 | RETURN_IF_ERROR(_helper.init(state, p.is_serial_operator(), p.node_id(), p.operator_id(), |
184 | 4 | _filter_dependencies, p.get_name() + "_FILTER_DEPENDENCY")); |
185 | 4 | RETURN_IF_ERROR(_init_profile()); |
186 | 4 | set_scan_ranges(state, info.scan_ranges); |
187 | | |
188 | 4 | _wait_for_rf_timer = ADD_TIMER(common_profile(), "WaitForRuntimeFilter"); |
189 | 4 | _instance_idx = info.task_idx; |
190 | 4 | return Status::OK(); |
191 | 4 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Line | Count | Source | 173 | 3 | Status ScanLocalState<Derived>::init(RuntimeState* state, LocalStateInfo& info) { | 174 | 3 | RETURN_IF_ERROR(PipelineXLocalState<>::init(state, info)); | 175 | 3 | _scan_dependency = Dependency::create_shared(_parent->operator_id(), _parent->node_id(), | 176 | 3 | _parent->get_name() + "_DEPENDENCY"); | 177 | 3 | _wait_for_dependency_timer = ADD_TIMER_WITH_LEVEL( | 178 | 3 | common_profile(), "WaitForDependency[" + _scan_dependency->name() + "]Time", 1); | 179 | 3 | SCOPED_TIMER(exec_time_counter()); | 180 | 3 | SCOPED_TIMER(_init_timer); | 181 | 3 | auto& p = _parent->cast<typename Derived::Parent>(); | 182 | 3 | _max_pushdown_conditions_per_column = p._max_pushdown_conditions_per_column; | 183 | 3 | RETURN_IF_ERROR(_helper.init(state, p.is_serial_operator(), p.node_id(), p.operator_id(), | 184 | 3 | _filter_dependencies, p.get_name() + "_FILTER_DEPENDENCY")); | 185 | 3 | RETURN_IF_ERROR(_init_profile()); | 186 | 3 | set_scan_ranges(state, info.scan_ranges); | 187 | | | 188 | 3 | _wait_for_rf_timer = ADD_TIMER(common_profile(), "WaitForRuntimeFilter"); | 189 | 3 | _instance_idx = info.task_idx; | 190 | 3 | return Status::OK(); | 191 | 3 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Line | Count | Source | 173 | 1 | Status ScanLocalState<Derived>::init(RuntimeState* state, LocalStateInfo& info) { | 174 | 1 | RETURN_IF_ERROR(PipelineXLocalState<>::init(state, info)); | 175 | 1 | _scan_dependency = Dependency::create_shared(_parent->operator_id(), _parent->node_id(), | 176 | 1 | _parent->get_name() + "_DEPENDENCY"); | 177 | 1 | _wait_for_dependency_timer = ADD_TIMER_WITH_LEVEL( | 178 | 1 | common_profile(), "WaitForDependency[" + _scan_dependency->name() + "]Time", 1); | 179 | 1 | SCOPED_TIMER(exec_time_counter()); | 180 | 1 | SCOPED_TIMER(_init_timer); | 181 | 1 | auto& p = _parent->cast<typename Derived::Parent>(); | 182 | 1 | _max_pushdown_conditions_per_column = p._max_pushdown_conditions_per_column; | 183 | 1 | RETURN_IF_ERROR(_helper.init(state, p.is_serial_operator(), p.node_id(), p.operator_id(), | 184 | 1 | _filter_dependencies, p.get_name() + "_FILTER_DEPENDENCY")); | 185 | 1 | RETURN_IF_ERROR(_init_profile()); | 186 | 1 | set_scan_ranges(state, info.scan_ranges); | 187 | | | 188 | 1 | _wait_for_rf_timer = ADD_TIMER(common_profile(), "WaitForRuntimeFilter"); | 189 | 1 | _instance_idx = info.task_idx; | 190 | 1 | return Status::OK(); | 191 | 1 | } |
|
192 | | |
193 | | static std::string predicates_to_string( |
194 | | const phmap::flat_hash_map<int, std::vector<std::shared_ptr<ColumnPredicate>>>& |
195 | 0 | slot_id_to_predicates) { |
196 | 0 | fmt::memory_buffer debug_string_buffer; |
197 | 0 | for (const auto& [slot_id, predicates] : slot_id_to_predicates) { |
198 | 0 | if (predicates.empty()) { |
199 | 0 | continue; |
200 | 0 | } |
201 | 0 | fmt::format_to(debug_string_buffer, "Slot ID: {}: [", slot_id); |
202 | 0 | for (const auto& predicate : predicates) { |
203 | 0 | fmt::format_to(debug_string_buffer, "{{{}}}, ", predicate->debug_string()); |
204 | 0 | } |
205 | 0 | fmt::format_to(debug_string_buffer, "] "); |
206 | 0 | } |
207 | 0 | return fmt::to_string(debug_string_buffer); |
208 | 0 | } |
209 | | |
210 | | template <typename Derived> |
211 | 0 | Status ScanLocalState<Derived>::open(RuntimeState* state) { |
212 | 0 | SCOPED_TIMER(exec_time_counter()); |
213 | 0 | SCOPED_TIMER(_open_timer); |
214 | 0 | if (_opened) { |
215 | 0 | return Status::OK(); |
216 | 0 | } |
217 | 0 | RETURN_IF_ERROR(PipelineXLocalState<>::open(state)); |
218 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
219 | | |
220 | | // init id_file_map() for runtime state |
221 | 0 | std::vector<SlotDescriptor*> slots = p._output_tuple_desc->slots(); |
222 | 0 | for (auto slot : slots) { |
223 | 0 | if (slot->col_name().starts_with(BeConsts::GLOBAL_ROWID_COL)) { |
224 | 0 | state->set_id_file_map(); |
225 | 0 | } |
226 | 0 | } |
227 | |
|
228 | 0 | _common_expr_ctxs_push_down.resize(p._common_expr_ctxs_push_down.size()); |
229 | 0 | for (size_t i = 0; i < _common_expr_ctxs_push_down.size(); i++) { |
230 | 0 | RETURN_IF_ERROR( |
231 | 0 | p._common_expr_ctxs_push_down[i]->clone(state, _common_expr_ctxs_push_down[i])); |
232 | 0 | } |
233 | 0 | size_t conjuncts_before = _conjuncts.size(); |
234 | 0 | RETURN_IF_ERROR(_helper.acquire_runtime_filter(state, _conjuncts, p.row_descriptor())); |
235 | 0 | if (_conjuncts.size() > conjuncts_before) { |
236 | 0 | RETURN_IF_ERROR(_on_runtime_filter_update()); |
237 | 0 | } |
238 | | |
239 | | // Disable condition cache in topn filter valid. TODO:: Try to support the topn filter in condition cache |
240 | 0 | if (state->query_options().condition_cache_digest && p._topn_filter_source_node_ids.empty()) { |
241 | 0 | _condition_cache_digest = state->query_options().condition_cache_digest; |
242 | 0 | for (auto& conjunct : _conjuncts) { |
243 | 0 | _condition_cache_digest = conjunct->get_digest(_condition_cache_digest); |
244 | 0 | if (!_condition_cache_digest) { |
245 | 0 | break; |
246 | 0 | } |
247 | 0 | } |
248 | 0 | } else { |
249 | 0 | _condition_cache_digest = 0; |
250 | 0 | } |
251 | |
|
252 | 0 | RETURN_IF_ERROR(_process_conjuncts(state)); |
253 | | |
254 | 0 | if (state->enable_profile()) { |
255 | 0 | custom_profile()->add_info_string("PushDownPredicates", |
256 | 0 | predicates_to_string(_slot_id_to_predicates)); |
257 | 0 | } |
258 | |
|
259 | 0 | auto status = _eos ? Status::OK() : _prepare_scanners(); |
260 | 0 | RETURN_IF_ERROR(status); |
261 | 0 | if (auto ctx = _scanner_ctx.load()) { |
262 | 0 | DCHECK(!_eos && _num_scanners->value() > 0); |
263 | 0 | RETURN_IF_ERROR(ctx->init()); |
264 | 0 | } |
265 | 0 | _opened = true; |
266 | 0 | return status; |
267 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE4openEPNS_12RuntimeStateE |
268 | | |
269 | | static void init_slot_value_range( |
270 | | phmap::flat_hash_map<int, ColumnValueRangeType>& slot_id_to_value_range, |
271 | 0 | SlotDescriptor* slot, const DataTypePtr type_desc) { |
272 | 0 | switch (type_desc->get_primitive_type()) { |
273 | 0 | #define M(NAME) \ |
274 | 0 | case TYPE_##NAME: { \ |
275 | 0 | ColumnValueRange<TYPE_##NAME> range(slot->col_name(), slot->is_nullable(), \ |
276 | 0 | cast_set<int>(type_desc->get_precision()), \ |
277 | 0 | cast_set<int>(type_desc->get_scale())); \ |
278 | 0 | slot_id_to_value_range[slot->id()] = std::move(range); \ |
279 | 0 | break; \ |
280 | 0 | } |
281 | 0 | #define APPLY_FOR_SCALAR_TYPE(M) \ |
282 | 0 | M(TINYINT) \ |
283 | 0 | M(SMALLINT) \ |
284 | 0 | M(INT) \ |
285 | 0 | M(BIGINT) \ |
286 | 0 | M(LARGEINT) \ |
287 | 0 | M(FLOAT) \ |
288 | 0 | M(DOUBLE) \ |
289 | 0 | M(CHAR) \ |
290 | 0 | M(DATE) \ |
291 | 0 | M(DATETIME) \ |
292 | 0 | M(DATEV2) \ |
293 | 0 | M(DATETIMEV2) \ |
294 | 0 | M(TIMESTAMPTZ) \ |
295 | 0 | M(VARCHAR) \ |
296 | 0 | M(STRING) \ |
297 | 0 | M(DECIMAL32) \ |
298 | 0 | M(DECIMAL64) \ |
299 | 0 | M(DECIMAL128I) \ |
300 | 0 | M(DECIMAL256) \ |
301 | 0 | M(DECIMALV2) \ |
302 | 0 | M(BOOLEAN) \ |
303 | 0 | M(IPV4) \ |
304 | 0 | M(IPV6) |
305 | 0 | APPLY_FOR_SCALAR_TYPE(M) |
306 | 0 | #undef M |
307 | 0 | default: { |
308 | 0 | break; |
309 | 0 | } |
310 | 0 | } |
311 | 0 | } |
312 | | |
313 | | /// Step 1 of the scan-key generation pipeline. |
314 | | /// |
315 | | /// Parse SQL WHERE conjuncts into per-column ColumnValueRange objects stored in |
316 | | /// _slot_id_to_value_range. Each ColumnValueRange captures all constraints on |
317 | | /// one column (fixed values from IN / =, or min/max bounds from < / <= / > / >=). |
318 | | /// |
319 | | /// Example – "WHERE k1 IN (1, 2) AND k2 >= 5 AND k2 < 10 AND v > 100": |
320 | | /// => ColumnValueRange<k1>: fixed_values = {1, 2} |
321 | | /// => ColumnValueRange<k2>: scope [5, 10) (low=5 >=, high=10 <) |
322 | | /// => ColumnValueRange<v>: scope (100, MAX] (low=100 >, high=MAX <=) |
323 | | /// The k1/k2 ranges will later become scan keys (since they're key columns); |
324 | | /// v's range stays as a residual predicate / olap filter. |
325 | | /// |
326 | | /// After this step, _build_key_ranges_and_filters() picks up the key-column |
327 | | /// ColumnValueRanges and feeds them to OlapScanKeys::extend_scan_key(). |
328 | | template <typename Derived> |
329 | 0 | Status ScanLocalState<Derived>::_normalize_conjuncts(RuntimeState* state) { |
330 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
331 | | // The conjuncts is always on output tuple, so use _output_tuple_desc; |
332 | 0 | std::vector<SlotDescriptor*> slots = p._output_tuple_desc->slots(); |
333 | |
|
334 | 0 | for (auto& slot : slots) { |
335 | 0 | init_slot_value_range(_slot_id_to_value_range, slot, slot->type()); |
336 | 0 | _slot_id_to_predicates.insert( |
337 | 0 | {slot->id(), std::vector<std::shared_ptr<ColumnPredicate>>()}); |
338 | 0 | } |
339 | |
|
340 | 0 | get_cast_types_for_variants(); |
341 | 0 | for (const auto& [colname, type] : _cast_types_for_variants) { |
342 | 0 | auto* slot = p._slot_id_to_slot_desc[p._colname_to_slot_id[colname]]; |
343 | 0 | init_slot_value_range(_slot_id_to_value_range, slot, type); |
344 | 0 | _slot_id_to_predicates.insert( |
345 | 0 | {slot->id(), std::vector<std::shared_ptr<ColumnPredicate>>()}); |
346 | 0 | } |
347 | |
|
348 | 0 | RETURN_IF_ERROR(_get_topn_filters(state)); |
349 | | |
350 | 0 | for (auto it = _conjuncts.begin(); it != _conjuncts.end();) { |
351 | 0 | auto& conjunct = *it; |
352 | 0 | if (conjunct->root()) { |
353 | 0 | VExprSPtr new_root; |
354 | 0 | RETURN_IF_ERROR(_normalize_predicate(conjunct.get(), conjunct->root(), new_root)); |
355 | 0 | if (new_root) { |
356 | 0 | conjunct->set_root(new_root); |
357 | 0 | if (_should_push_down_common_expr(conjunct->root())) { |
358 | 0 | _common_expr_ctxs_push_down.emplace_back(conjunct); |
359 | 0 | it = _conjuncts.erase(it); |
360 | 0 | continue; |
361 | 0 | } |
362 | 0 | } else { // All conjuncts are pushed down as predicate column |
363 | 0 | _stale_expr_ctxs.emplace_back( |
364 | 0 | conjunct); // avoid function context and constant str being freed |
365 | 0 | it = _conjuncts.erase(it); |
366 | 0 | continue; |
367 | 0 | } |
368 | 0 | } |
369 | 0 | ++it; |
370 | 0 | } |
371 | | |
372 | 0 | if (state->enable_profile()) { |
373 | 0 | std::string message; |
374 | 0 | for (auto& conjunct : _conjuncts) { |
375 | 0 | if (conjunct->root()) { |
376 | 0 | if (!message.empty()) { |
377 | 0 | message += ", "; |
378 | 0 | } |
379 | 0 | message += conjunct->root()->debug_string(); |
380 | 0 | } |
381 | 0 | } |
382 | 0 | custom_profile()->add_info_string("RemainedPredicates", message); |
383 | 0 | } |
384 | |
|
385 | 0 | for (auto& it : _slot_id_to_value_range) { |
386 | 0 | std::visit( |
387 | 0 | [&](auto&& range) { |
388 | 0 | if (range.is_empty_value_range()) { |
389 | 0 | _eos = true; |
390 | 0 | _scan_dependency->set_ready(); |
391 | 0 | } |
392 | 0 | }, Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaS6_ |
393 | 0 | it.second); |
394 | 0 | } |
395 | |
|
396 | 0 | return Status::OK(); |
397 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE |
398 | | |
399 | | template <typename Derived> |
400 | | Status ScanLocalState<Derived>::_normalize_predicate(VExprContext* context, const VExprSPtr& root, |
401 | 105 | VExprSPtr& output_expr) { |
402 | 105 | auto expr_root = root->is_rf_wrapper() ? root->get_impl() : root; |
403 | 105 | PushDownType pdt = PushDownType::UNACCEPTABLE; |
404 | 105 | if (dynamic_cast<VirtualSlotRef*>(expr_root.get())) { |
405 | | // If the expr has virtual slot ref, we need to keep it in the tree. |
406 | 0 | output_expr = expr_root; |
407 | 0 | return Status::OK(); |
408 | 0 | } |
409 | | |
410 | 105 | SlotDescriptor* slot = nullptr; |
411 | 105 | ColumnValueRangeType* range = nullptr; |
412 | 105 | RETURN_IF_ERROR(_eval_const_conjuncts(context, &pdt)); |
413 | 105 | if (pdt == PushDownType::ACCEPTABLE) { |
414 | 2 | output_expr = nullptr; |
415 | 2 | return Status::OK(); |
416 | 2 | } |
417 | 103 | std::shared_ptr<VSlotRef> slotref; |
418 | 188 | for (const auto& child : expr_root->children()) { |
419 | 188 | if (VExpr::expr_without_cast(child)->node_type() != TExprNodeType::SLOT_REF) { |
420 | | // not a slot ref(column) |
421 | 87 | continue; |
422 | 87 | } |
423 | 101 | slotref = std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(child)); |
424 | 101 | } |
425 | 103 | if (_is_predicate_acting_on_slot(expr_root->children(), &slot, &range)) { |
426 | 99 | Status status = Status::OK(); |
427 | 99 | std::visit( |
428 | 99 | [&](auto& value_range) { |
429 | 99 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; |
430 | 99 | { |
431 | 99 | Defer attach_defer = [&]() { |
432 | 99 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { |
433 | 0 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); |
434 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( |
435 | 0 | rf_expr->filter_id(), |
436 | 0 | rf_expr->predicate_filtered_rows_counter(), |
437 | 0 | rf_expr->predicate_input_rows_counter(), |
438 | 0 | rf_expr->predicate_always_true_rows_counter(), |
439 | 0 | context->get_runtime_filter_selectivity()); |
440 | 0 | } |
441 | 99 | }; Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Line | Count | Source | 431 | 15 | Defer attach_defer = [&]() { | 432 | 15 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 0 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 0 | rf_expr->filter_id(), | 436 | 0 | rf_expr->predicate_filtered_rows_counter(), | 437 | 0 | rf_expr->predicate_input_rows_counter(), | 438 | 0 | rf_expr->predicate_always_true_rows_counter(), | 439 | 0 | context->get_runtime_filter_selectivity()); | 440 | 0 | } | 441 | 15 | }; |
Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Line | Count | Source | 431 | 63 | Defer attach_defer = [&]() { | 432 | 63 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 0 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 0 | rf_expr->filter_id(), | 436 | 0 | rf_expr->predicate_filtered_rows_counter(), | 437 | 0 | rf_expr->predicate_input_rows_counter(), | 438 | 0 | rf_expr->predicate_always_true_rows_counter(), | 439 | 0 | context->get_runtime_filter_selectivity()); | 440 | 0 | } | 441 | 63 | }; |
Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Line | Count | Source | 431 | 21 | Defer attach_defer = [&]() { | 432 | 21 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 0 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 0 | rf_expr->filter_id(), | 436 | 0 | rf_expr->predicate_filtered_rows_counter(), | 437 | 0 | rf_expr->predicate_input_rows_counter(), | 438 | 0 | rf_expr->predicate_always_true_rows_counter(), | 439 | 0 | context->get_runtime_filter_selectivity()); | 440 | 0 | } | 441 | 21 | }; |
Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ENKUlvE_clEv |
442 | 99 | switch (expr->node_type()) { |
443 | 10 | case TExprNodeType::IN_PRED: |
444 | 10 | RETURN_IF_PUSH_DOWN( |
445 | 10 | _normalize_in_predicate(context, expr, slot, |
446 | 10 | _slot_id_to_predicates[slot->id()], |
447 | 10 | value_range, &pdt), |
448 | 10 | status); |
449 | 10 | break; |
450 | 85 | case TExprNodeType::BINARY_PRED: |
451 | 85 | RETURN_IF_PUSH_DOWN( |
452 | 85 | _normalize_binary_predicate(context, expr, slot, |
453 | 85 | _slot_id_to_predicates[slot->id()], |
454 | 85 | value_range, &pdt), |
455 | 85 | status); |
456 | 85 | break; |
457 | 4 | case TExprNodeType::FUNCTION_CALL: |
458 | 4 | if (expr->is_topn_filter()) { |
459 | 0 | RETURN_IF_PUSH_DOWN( |
460 | 0 | _normalize_topn_filter(context, expr, slot, |
461 | 0 | _slot_id_to_predicates[slot->id()], |
462 | 0 | &pdt), |
463 | 0 | status); |
464 | 4 | } else { |
465 | 4 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( |
466 | 4 | context, expr, slot, |
467 | 4 | _slot_id_to_predicates[slot->id()], |
468 | 4 | value_range, &pdt), |
469 | 4 | status); |
470 | 4 | } |
471 | 4 | break; |
472 | 4 | case TExprNodeType::BLOOM_PRED: |
473 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( |
474 | 0 | context, root, slot, |
475 | 0 | _slot_id_to_predicates[slot->id()], &pdt), |
476 | 0 | status); |
477 | 0 | break; |
478 | 0 | default: |
479 | 0 | break; |
480 | 99 | } |
481 | 99 | } |
482 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED |
483 | 99 | if (state()->enable_function_pushdown()) { |
484 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), |
485 | 0 | status); |
486 | 0 | } |
487 | 99 | }, Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Line | Count | Source | 428 | 15 | [&](auto& value_range) { | 429 | 15 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 430 | 15 | { | 431 | 15 | Defer attach_defer = [&]() { | 432 | 15 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 15 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 15 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 15 | rf_expr->filter_id(), | 436 | 15 | rf_expr->predicate_filtered_rows_counter(), | 437 | 15 | rf_expr->predicate_input_rows_counter(), | 438 | 15 | rf_expr->predicate_always_true_rows_counter(), | 439 | 15 | context->get_runtime_filter_selectivity()); | 440 | 15 | } | 441 | 15 | }; | 442 | 15 | switch (expr->node_type()) { | 443 | 6 | case TExprNodeType::IN_PRED: | 444 | 6 | RETURN_IF_PUSH_DOWN( | 445 | 6 | _normalize_in_predicate(context, expr, slot, | 446 | 6 | _slot_id_to_predicates[slot->id()], | 447 | 6 | value_range, &pdt), | 448 | 6 | status); | 449 | 6 | break; | 450 | 7 | case TExprNodeType::BINARY_PRED: | 451 | 7 | RETURN_IF_PUSH_DOWN( | 452 | 7 | _normalize_binary_predicate(context, expr, slot, | 453 | 7 | _slot_id_to_predicates[slot->id()], | 454 | 7 | value_range, &pdt), | 455 | 7 | status); | 456 | 7 | break; | 457 | 2 | case TExprNodeType::FUNCTION_CALL: | 458 | 2 | if (expr->is_topn_filter()) { | 459 | 0 | RETURN_IF_PUSH_DOWN( | 460 | 0 | _normalize_topn_filter(context, expr, slot, | 461 | 0 | _slot_id_to_predicates[slot->id()], | 462 | 0 | &pdt), | 463 | 0 | status); | 464 | 2 | } else { | 465 | 2 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 466 | 2 | context, expr, slot, | 467 | 2 | _slot_id_to_predicates[slot->id()], | 468 | 2 | value_range, &pdt), | 469 | 2 | status); | 470 | 2 | } | 471 | 2 | break; | 472 | 2 | case TExprNodeType::BLOOM_PRED: | 473 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 474 | 0 | context, root, slot, | 475 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 476 | 0 | status); | 477 | 0 | break; | 478 | 0 | default: | 479 | 0 | break; | 480 | 15 | } | 481 | 15 | } | 482 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 483 | 15 | if (state()->enable_function_pushdown()) { | 484 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 485 | 0 | status); | 486 | 0 | } | 487 | 15 | }, |
Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Line | Count | Source | 428 | 63 | [&](auto& value_range) { | 429 | 63 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 430 | 63 | { | 431 | 63 | Defer attach_defer = [&]() { | 432 | 63 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 63 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 63 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 63 | rf_expr->filter_id(), | 436 | 63 | rf_expr->predicate_filtered_rows_counter(), | 437 | 63 | rf_expr->predicate_input_rows_counter(), | 438 | 63 | rf_expr->predicate_always_true_rows_counter(), | 439 | 63 | context->get_runtime_filter_selectivity()); | 440 | 63 | } | 441 | 63 | }; | 442 | 63 | switch (expr->node_type()) { | 443 | 2 | case TExprNodeType::IN_PRED: | 444 | 2 | RETURN_IF_PUSH_DOWN( | 445 | 2 | _normalize_in_predicate(context, expr, slot, | 446 | 2 | _slot_id_to_predicates[slot->id()], | 447 | 2 | value_range, &pdt), | 448 | 2 | status); | 449 | 2 | break; | 450 | 60 | case TExprNodeType::BINARY_PRED: | 451 | 60 | RETURN_IF_PUSH_DOWN( | 452 | 60 | _normalize_binary_predicate(context, expr, slot, | 453 | 60 | _slot_id_to_predicates[slot->id()], | 454 | 60 | value_range, &pdt), | 455 | 60 | status); | 456 | 60 | break; | 457 | 1 | case TExprNodeType::FUNCTION_CALL: | 458 | 1 | if (expr->is_topn_filter()) { | 459 | 0 | RETURN_IF_PUSH_DOWN( | 460 | 0 | _normalize_topn_filter(context, expr, slot, | 461 | 0 | _slot_id_to_predicates[slot->id()], | 462 | 0 | &pdt), | 463 | 0 | status); | 464 | 1 | } else { | 465 | 1 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 466 | 1 | context, expr, slot, | 467 | 1 | _slot_id_to_predicates[slot->id()], | 468 | 1 | value_range, &pdt), | 469 | 1 | status); | 470 | 1 | } | 471 | 1 | break; | 472 | 1 | case TExprNodeType::BLOOM_PRED: | 473 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 474 | 0 | context, root, slot, | 475 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 476 | 0 | status); | 477 | 0 | break; | 478 | 0 | default: | 479 | 0 | break; | 480 | 63 | } | 481 | 63 | } | 482 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 483 | 63 | if (state()->enable_function_pushdown()) { | 484 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 485 | 0 | status); | 486 | 0 | } | 487 | 63 | }, |
Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Line | Count | Source | 428 | 21 | [&](auto& value_range) { | 429 | 21 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 430 | 21 | { | 431 | 21 | Defer attach_defer = [&]() { | 432 | 21 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 21 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 21 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 21 | rf_expr->filter_id(), | 436 | 21 | rf_expr->predicate_filtered_rows_counter(), | 437 | 21 | rf_expr->predicate_input_rows_counter(), | 438 | 21 | rf_expr->predicate_always_true_rows_counter(), | 439 | 21 | context->get_runtime_filter_selectivity()); | 440 | 21 | } | 441 | 21 | }; | 442 | 21 | switch (expr->node_type()) { | 443 | 2 | case TExprNodeType::IN_PRED: | 444 | 2 | RETURN_IF_PUSH_DOWN( | 445 | 2 | _normalize_in_predicate(context, expr, slot, | 446 | 2 | _slot_id_to_predicates[slot->id()], | 447 | 2 | value_range, &pdt), | 448 | 2 | status); | 449 | 2 | break; | 450 | 18 | case TExprNodeType::BINARY_PRED: | 451 | 18 | RETURN_IF_PUSH_DOWN( | 452 | 18 | _normalize_binary_predicate(context, expr, slot, | 453 | 18 | _slot_id_to_predicates[slot->id()], | 454 | 18 | value_range, &pdt), | 455 | 18 | status); | 456 | 18 | break; | 457 | 1 | case TExprNodeType::FUNCTION_CALL: | 458 | 1 | if (expr->is_topn_filter()) { | 459 | 0 | RETURN_IF_PUSH_DOWN( | 460 | 0 | _normalize_topn_filter(context, expr, slot, | 461 | 0 | _slot_id_to_predicates[slot->id()], | 462 | 0 | &pdt), | 463 | 0 | status); | 464 | 1 | } else { | 465 | 1 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 466 | 1 | context, expr, slot, | 467 | 1 | _slot_id_to_predicates[slot->id()], | 468 | 1 | value_range, &pdt), | 469 | 1 | status); | 470 | 1 | } | 471 | 1 | break; | 472 | 1 | case TExprNodeType::BLOOM_PRED: | 473 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 474 | 0 | context, root, slot, | 475 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 476 | 0 | status); | 477 | 0 | break; | 478 | 0 | default: | 479 | 0 | break; | 480 | 21 | } | 481 | 21 | } | 482 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 483 | 21 | if (state()->enable_function_pushdown()) { | 484 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 485 | 0 | status); | 486 | 0 | } | 487 | 21 | }, |
Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE35EEEEEDaSC_ |
488 | 99 | *range); |
489 | 99 | RETURN_IF_ERROR(status); |
490 | 99 | } |
491 | 103 | if (pdt == PushDownType::ACCEPTABLE && slotref != nullptr && |
492 | 103 | slotref->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { |
493 | | // remaining it in the expr tree, in order to filter by function if the pushdown |
494 | | // predicate is not applied |
495 | 0 | output_expr = expr_root; // remaining in conjunct tree |
496 | 0 | return Status::OK(); |
497 | 0 | } |
498 | | |
499 | 103 | if (pdt == PushDownType::ACCEPTABLE && _is_key_column(slot->col_name())) { |
500 | 96 | output_expr = nullptr; |
501 | 96 | return Status::OK(); |
502 | 96 | } else { |
503 | | // for PARTIAL_ACCEPTABLE and UNACCEPTABLE, do not remove expr from the tree |
504 | 7 | output_expr = root; |
505 | 7 | return Status::OK(); |
506 | 7 | } |
507 | 0 | output_expr = root; |
508 | 0 | return Status::OK(); |
509 | 103 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ Line | Count | Source | 401 | 105 | VExprSPtr& output_expr) { | 402 | 105 | auto expr_root = root->is_rf_wrapper() ? root->get_impl() : root; | 403 | 105 | PushDownType pdt = PushDownType::UNACCEPTABLE; | 404 | 105 | if (dynamic_cast<VirtualSlotRef*>(expr_root.get())) { | 405 | | // If the expr has virtual slot ref, we need to keep it in the tree. | 406 | 0 | output_expr = expr_root; | 407 | 0 | return Status::OK(); | 408 | 0 | } | 409 | | | 410 | 105 | SlotDescriptor* slot = nullptr; | 411 | 105 | ColumnValueRangeType* range = nullptr; | 412 | 105 | RETURN_IF_ERROR(_eval_const_conjuncts(context, &pdt)); | 413 | 105 | if (pdt == PushDownType::ACCEPTABLE) { | 414 | 2 | output_expr = nullptr; | 415 | 2 | return Status::OK(); | 416 | 2 | } | 417 | 103 | std::shared_ptr<VSlotRef> slotref; | 418 | 188 | for (const auto& child : expr_root->children()) { | 419 | 188 | if (VExpr::expr_without_cast(child)->node_type() != TExprNodeType::SLOT_REF) { | 420 | | // not a slot ref(column) | 421 | 87 | continue; | 422 | 87 | } | 423 | 101 | slotref = std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(child)); | 424 | 101 | } | 425 | 103 | if (_is_predicate_acting_on_slot(expr_root->children(), &slot, &range)) { | 426 | 99 | Status status = Status::OK(); | 427 | 99 | std::visit( | 428 | 99 | [&](auto& value_range) { | 429 | 99 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 430 | 99 | { | 431 | 99 | Defer attach_defer = [&]() { | 432 | 99 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 433 | 99 | auto* rf_expr = assert_cast<RuntimeFilterExpr*>(root.get()); | 434 | 99 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 435 | 99 | rf_expr->filter_id(), | 436 | 99 | rf_expr->predicate_filtered_rows_counter(), | 437 | 99 | rf_expr->predicate_input_rows_counter(), | 438 | 99 | rf_expr->predicate_always_true_rows_counter(), | 439 | 99 | context->get_runtime_filter_selectivity()); | 440 | 99 | } | 441 | 99 | }; | 442 | 99 | switch (expr->node_type()) { | 443 | 99 | case TExprNodeType::IN_PRED: | 444 | 99 | RETURN_IF_PUSH_DOWN( | 445 | 99 | _normalize_in_predicate(context, expr, slot, | 446 | 99 | _slot_id_to_predicates[slot->id()], | 447 | 99 | value_range, &pdt), | 448 | 99 | status); | 449 | 99 | break; | 450 | 99 | case TExprNodeType::BINARY_PRED: | 451 | 99 | RETURN_IF_PUSH_DOWN( | 452 | 99 | _normalize_binary_predicate(context, expr, slot, | 453 | 99 | _slot_id_to_predicates[slot->id()], | 454 | 99 | value_range, &pdt), | 455 | 99 | status); | 456 | 99 | break; | 457 | 99 | case TExprNodeType::FUNCTION_CALL: | 458 | 99 | if (expr->is_topn_filter()) { | 459 | 99 | RETURN_IF_PUSH_DOWN( | 460 | 99 | _normalize_topn_filter(context, expr, slot, | 461 | 99 | _slot_id_to_predicates[slot->id()], | 462 | 99 | &pdt), | 463 | 99 | status); | 464 | 99 | } else { | 465 | 99 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 466 | 99 | context, expr, slot, | 467 | 99 | _slot_id_to_predicates[slot->id()], | 468 | 99 | value_range, &pdt), | 469 | 99 | status); | 470 | 99 | } | 471 | 99 | break; | 472 | 99 | case TExprNodeType::BLOOM_PRED: | 473 | 99 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 474 | 99 | context, root, slot, | 475 | 99 | _slot_id_to_predicates[slot->id()], &pdt), | 476 | 99 | status); | 477 | 99 | break; | 478 | 99 | default: | 479 | 99 | break; | 480 | 99 | } | 481 | 99 | } | 482 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 483 | 99 | if (state()->enable_function_pushdown()) { | 484 | 99 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 485 | 99 | status); | 486 | 99 | } | 487 | 99 | }, | 488 | 99 | *range); | 489 | 99 | RETURN_IF_ERROR(status); | 490 | 99 | } | 491 | 103 | if (pdt == PushDownType::ACCEPTABLE && slotref != nullptr && | 492 | 103 | slotref->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { | 493 | | // remaining it in the expr tree, in order to filter by function if the pushdown | 494 | | // predicate is not applied | 495 | 0 | output_expr = expr_root; // remaining in conjunct tree | 496 | 0 | return Status::OK(); | 497 | 0 | } | 498 | | | 499 | 103 | if (pdt == PushDownType::ACCEPTABLE && _is_key_column(slot->col_name())) { | 500 | 96 | output_expr = nullptr; | 501 | 96 | return Status::OK(); | 502 | 96 | } else { | 503 | | // for PARTIAL_ACCEPTABLE and UNACCEPTABLE, do not remove expr from the tree | 504 | 7 | output_expr = root; | 505 | 7 | return Status::OK(); | 506 | 7 | } | 507 | 0 | output_expr = root; | 508 | 0 | return Status::OK(); | 509 | 103 | } |
|
510 | | |
511 | | Status ScanLocalStateBase::_normalize_bloom_filter( |
512 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
513 | 0 | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, PushDownType* pdt) { |
514 | 0 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
515 | 0 | Defer defer = [&]() { |
516 | 0 | if (pred) { |
517 | 0 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
518 | 0 | predicates.emplace_back(pred); |
519 | 0 | } else { |
520 | | // If exception occurs during processing, do not push down |
521 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
522 | 0 | } |
523 | 0 | }; |
524 | 0 | DCHECK(TExprNodeType::BLOOM_PRED == root->node_type()); |
525 | 0 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; |
526 | 0 | DCHECK(expr->get_num_children() == 1); |
527 | 0 | DCHECK(root->is_rf_wrapper()); |
528 | 0 | *pdt = _should_push_down_bloom_filter(); |
529 | 0 | if (*pdt != PushDownType::UNACCEPTABLE) { |
530 | 0 | pred = create_bloom_filter_predicate( |
531 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
532 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT ? expr->get_child(0)->data_type() |
533 | 0 | : slot->type(), |
534 | 0 | expr->get_bloom_filter_func()); |
535 | 0 | } |
536 | 0 | return Status::OK(); |
537 | 0 | } |
538 | | |
539 | | Status ScanLocalStateBase::_normalize_topn_filter( |
540 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
541 | 0 | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, PushDownType* pdt) { |
542 | 0 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
543 | 0 | Defer defer = [&]() { |
544 | 0 | if (pred) { |
545 | 0 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
546 | 0 | predicates.emplace_back(pred); |
547 | 0 | } else { |
548 | | // If exception occurs during processing, do not push down |
549 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
550 | 0 | } |
551 | 0 | }; |
552 | 0 | DCHECK(root->is_topn_filter()); |
553 | 0 | *pdt = _should_push_down_topn_filter(); |
554 | 0 | if (*pdt != PushDownType::UNACCEPTABLE) { |
555 | 0 | auto& tmp = _state->get_query_ctx()->get_runtime_predicate( |
556 | 0 | assert_cast<VTopNPred*>(root.get())->source_node_id()); |
557 | 0 | if (_push_down_topn(tmp)) { |
558 | 0 | pred = tmp.get_predicate(_parent->node_id()); |
559 | 0 | } |
560 | 0 | } |
561 | 0 | return Status::OK(); |
562 | 0 | } |
563 | | |
564 | | Status ScanLocalStateBase::_normalize_function_filters(VExprContext* expr_ctx, SlotDescriptor* slot, |
565 | 0 | PushDownType* pdt) { |
566 | 0 | auto expr = expr_ctx->root()->is_rf_wrapper() ? expr_ctx->root()->get_impl() : expr_ctx->root(); |
567 | 0 | bool opposite = false; |
568 | 0 | VExpr* fn_expr = expr.get(); |
569 | 0 | if (TExprNodeType::COMPOUND_PRED == expr->node_type() && |
570 | 0 | expr->fn().name.function_name == "not") { |
571 | 0 | fn_expr = fn_expr->children()[0].get(); |
572 | 0 | opposite = true; |
573 | 0 | } |
574 | |
|
575 | 0 | if (fn_expr->is_like_expr()) { |
576 | 0 | doris::FunctionContext* fn_ctx = nullptr; |
577 | 0 | StringRef val; |
578 | 0 | PushDownType temp_pdt; |
579 | 0 | RETURN_IF_ERROR(_should_push_down_function_filter(assert_cast<VectorizedFnCall*>(fn_expr), |
580 | 0 | expr_ctx, &val, &fn_ctx, temp_pdt)); |
581 | 0 | if (temp_pdt != PushDownType::UNACCEPTABLE) { |
582 | 0 | std::string col = slot->col_name(); |
583 | 0 | _push_down_functions.emplace_back(opposite, col, fn_ctx, val); |
584 | 0 | *pdt = temp_pdt; |
585 | 0 | } |
586 | 0 | } |
587 | 0 | return Status::OK(); |
588 | 0 | } |
589 | | |
590 | | // only one level cast expr could push down for variant type |
591 | | // check if expr is cast and it's children is slot |
592 | 0 | static bool is_valid_push_down_cast(const VExprSPtrs& children) { |
593 | 0 | auto slot_expr = VExpr::expr_without_cast(children[0]); |
594 | 0 | return slot_expr->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT && |
595 | 0 | children[0]->node_type() == TExprNodeType::CAST_EXPR && |
596 | 0 | children[0]->children().at(0)->is_slot_ref(); |
597 | 0 | } |
598 | | |
599 | | template <typename Derived> |
600 | | bool ScanLocalState<Derived>::_is_predicate_acting_on_slot(const VExprSPtrs& children, |
601 | | SlotDescriptor** slot_desc, |
602 | 103 | ColumnValueRangeType** range) { |
603 | | // children[0] must be slot ref or cast(slot(variant) as type) |
604 | 103 | if (children.empty() || (children[0]->node_type() != TExprNodeType::SLOT_REF && |
605 | 101 | !is_valid_push_down_cast(children))) { |
606 | | // not a slot ref(column) |
607 | 2 | return false; |
608 | 2 | } |
609 | 101 | std::shared_ptr<VSlotRef> slot_ref = |
610 | 101 | std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(children[0])); |
611 | 101 | *slot_desc = |
612 | 101 | _parent->cast<typename Derived::Parent>()._slot_id_to_slot_desc[slot_ref->slot_id()]; |
613 | 101 | auto entry = _slot_id_to_predicates.find(slot_ref->slot_id()); |
614 | 101 | if (_slot_id_to_predicates.end() == entry) { |
615 | 2 | return false; |
616 | 2 | } |
617 | 99 | auto sid_to_range = _slot_id_to_value_range.find(slot_ref->slot_id()); |
618 | 99 | if (_slot_id_to_value_range.end() == sid_to_range) { |
619 | 0 | return false; |
620 | 0 | } |
621 | 99 | if (!_parent->cast<typename Derived::Parent>().can_push_down_column_predicate(*slot_desc)) { |
622 | 0 | return false; |
623 | 0 | } |
624 | 99 | *range = &(sid_to_range->second); |
625 | 99 | return true; |
626 | 99 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE28_is_predicate_acting_on_slotERKSt6vectorISt10shared_ptrINS_5VExprEESaIS6_EEPPNS_14SlotDescriptorEPPSt7variantIJNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEENSF_ILSG_4EEENSF_ILSG_5EEENSF_ILSG_6EEENSF_ILSG_7EEENSF_ILSG_8EEENSF_ILSG_9EEENSF_ILSG_36EEENSF_ILSG_37EEENSF_ILSG_15EEENSF_ILSG_10EEENSF_ILSG_23EEENSF_ILSG_11EEENSF_ILSG_25EEENSF_ILSG_12EEENSF_ILSG_26EEENSF_ILSG_42EEENSF_ILSG_20EEENSF_ILSG_2EEENSF_ILSG_28EEENSF_ILSG_29EEENSF_ILSG_30EEENSF_ILSG_35EEEEE Line | Count | Source | 602 | 103 | ColumnValueRangeType** range) { | 603 | | // children[0] must be slot ref or cast(slot(variant) as type) | 604 | 103 | if (children.empty() || (children[0]->node_type() != TExprNodeType::SLOT_REF && | 605 | 101 | !is_valid_push_down_cast(children))) { | 606 | | // not a slot ref(column) | 607 | 2 | return false; | 608 | 2 | } | 609 | 101 | std::shared_ptr<VSlotRef> slot_ref = | 610 | 101 | std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(children[0])); | 611 | 101 | *slot_desc = | 612 | 101 | _parent->cast<typename Derived::Parent>()._slot_id_to_slot_desc[slot_ref->slot_id()]; | 613 | 101 | auto entry = _slot_id_to_predicates.find(slot_ref->slot_id()); | 614 | 101 | if (_slot_id_to_predicates.end() == entry) { | 615 | 2 | return false; | 616 | 2 | } | 617 | 99 | auto sid_to_range = _slot_id_to_value_range.find(slot_ref->slot_id()); | 618 | 99 | if (_slot_id_to_value_range.end() == sid_to_range) { | 619 | 0 | return false; | 620 | 0 | } | 621 | 99 | if (!_parent->cast<typename Derived::Parent>().can_push_down_column_predicate(*slot_desc)) { | 622 | 0 | return false; | 623 | 0 | } | 624 | 99 | *range = &(sid_to_range->second); | 625 | 99 | return true; | 626 | 99 | } |
|
627 | | |
628 | | template <typename Derived> |
629 | 0 | std::string ScanLocalState<Derived>::debug_string(int indentation_level) const { |
630 | 0 | fmt::memory_buffer debug_string_buffer; |
631 | 0 | fmt::format_to(debug_string_buffer, "{}, _eos = {} , _opened = {}", |
632 | 0 | PipelineXLocalState<>::debug_string(indentation_level), _eos.load(), |
633 | 0 | _opened.load()); |
634 | 0 | if (auto ctx = _scanner_ctx.load()) { |
635 | 0 | fmt::format_to(debug_string_buffer, ""); |
636 | 0 | fmt::format_to(debug_string_buffer, ", Scanner Context: {}", ctx->debug_string()); |
637 | 0 | } else { |
638 | 0 | fmt::format_to(debug_string_buffer, ""); |
639 | 0 | fmt::format_to(debug_string_buffer, ", Scanner Context: NULL"); |
640 | 0 | } |
641 | |
|
642 | 0 | return fmt::to_string(debug_string_buffer); |
643 | 0 | } Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE12debug_stringB5cxx11Ei |
644 | | |
645 | 105 | Status ScanLocalStateBase::_eval_const_conjuncts(VExprContext* expr_ctx, PushDownType* pdt) { |
646 | 105 | auto vexpr = |
647 | 105 | expr_ctx->root()->is_rf_wrapper() ? expr_ctx->root()->get_impl() : expr_ctx->root(); |
648 | | // Used to handle constant expressions, such as '1 = 1' _eval_const_conjuncts does not handle cases like 'colA = 1' |
649 | 105 | const char* constant_val = nullptr; |
650 | 105 | if (vexpr->is_constant()) { |
651 | 3 | std::shared_ptr<ColumnPtrWrapper> const_col_wrapper; |
652 | 3 | RETURN_IF_ERROR(vexpr->get_const_col(expr_ctx, &const_col_wrapper)); |
653 | 3 | if (const auto* const_column = |
654 | 3 | check_and_get_column<ColumnConst>(const_col_wrapper->column_ptr.get())) { |
655 | 1 | constant_val = const_column->get_data_at(0).data; |
656 | 1 | if (constant_val == nullptr || !*reinterpret_cast<const bool*>(constant_val)) { |
657 | 1 | *pdt = PushDownType::ACCEPTABLE; |
658 | 1 | _eos = true; |
659 | 1 | _scan_dependency->set_ready(); |
660 | 1 | } |
661 | 2 | } else if (const auto* bool_column = |
662 | 2 | check_and_get_column<ColumnUInt8>(const_col_wrapper->column_ptr.get())) { |
663 | | // TODO: If `vexpr->is_constant()` is true, a const column is expected here. |
664 | | // But now we still don't cover all predicates for const expression. |
665 | | // For example, for query `SELECT col FROM tbl WHERE 'PROMOTION' LIKE 'AAA%'`, |
666 | | // predicate `like` will return a ColumnVector<UInt8> which contains a single value. |
667 | 1 | LOG(WARNING) << "VExpr[" << vexpr->debug_string() |
668 | 1 | << "] should return a const column but actually is " |
669 | 1 | << const_col_wrapper->column_ptr->get_name(); |
670 | 1 | DCHECK_EQ(bool_column->size(), 1); |
671 | | /// TODO: There is a DCHECK here, but an additional check is still needed. It should return an error code. |
672 | 1 | if (bool_column->size() == 1) { |
673 | 1 | constant_val = bool_column->get_data_at(0).data; |
674 | 1 | if (constant_val == nullptr || !*reinterpret_cast<const bool*>(constant_val)) { |
675 | 1 | *pdt = PushDownType::ACCEPTABLE; |
676 | 1 | _eos = true; |
677 | 1 | _scan_dependency->set_ready(); |
678 | 1 | } |
679 | 1 | } else { |
680 | 0 | LOG(WARNING) << "Constant predicate in scan node should return a bool column with " |
681 | 0 | "`size == 1` but actually is " |
682 | 0 | << bool_column->size(); |
683 | 0 | } |
684 | 1 | } else { |
685 | 1 | LOG(WARNING) << "VExpr[" << vexpr->debug_string() |
686 | 1 | << "] should return a const column but actually is " |
687 | 1 | << const_col_wrapper->column_ptr->get_name(); |
688 | 1 | } |
689 | 3 | } |
690 | 105 | return Status::OK(); |
691 | 105 | } |
692 | | |
693 | | template <PrimitiveType T> |
694 | | Status ScanLocalStateBase::_normalize_in_predicate( |
695 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
696 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
697 | 10 | PushDownType* pdt) { |
698 | 10 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
699 | 10 | Defer defer = [&]() { |
700 | 10 | if (pred) { |
701 | 8 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
702 | 8 | predicates.emplace_back(pred); |
703 | 8 | } else { |
704 | | // If exception occurs during processing, do not push down |
705 | 2 | *pdt = PushDownType::UNACCEPTABLE; |
706 | 2 | } |
707 | 10 | }; Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 699 | 6 | Defer defer = [&]() { | 700 | 6 | if (pred) { | 701 | 4 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 4 | predicates.emplace_back(pred); | 703 | 4 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 2 | } | 707 | 6 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 699 | 2 | Defer defer = [&]() { | 700 | 2 | if (pred) { | 701 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 2 | predicates.emplace_back(pred); | 703 | 2 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 0 | } | 707 | 2 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 699 | 2 | Defer defer = [&]() { | 700 | 2 | if (pred) { | 701 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 2 | predicates.emplace_back(pred); | 703 | 2 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 0 | } | 707 | 2 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv |
708 | | |
709 | 10 | if (slot->get_virtual_column_expr() != nullptr) { |
710 | | // virtual column, do not push down |
711 | 0 | return Status::OK(); |
712 | 0 | } |
713 | | |
714 | 10 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
715 | 10 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); |
716 | 10 | *pdt = _should_push_down_in_predicate(); |
717 | 10 | if (*pdt == PushDownType::UNACCEPTABLE) { |
718 | 0 | return Status::OK(); |
719 | 0 | } |
720 | 10 | HybridSetBase::IteratorBase* iter = nullptr; |
721 | 10 | auto hybrid_set = root->get_set_func(); |
722 | | |
723 | 10 | auto is_in = false; |
724 | 10 | if (hybrid_set != nullptr) { |
725 | | // runtime filter produce VDirectInPredicate |
726 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { |
727 | 0 | iter = hybrid_set->begin(); |
728 | 0 | } |
729 | 0 | is_in = true; |
730 | 10 | } else { |
731 | | // normal in predicate |
732 | 10 | auto* tmp = assert_cast<VInPredicate*>(root.get()); |
733 | | |
734 | | // begin to push InPredicate value into ColumnValueRange |
735 | 10 | auto* state = reinterpret_cast<InState*>( |
736 | 10 | expr_ctx->fn_context(tmp->fn_context_index()) |
737 | 10 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); |
738 | | |
739 | | // xx in (col, xx, xx) should not be push down |
740 | 10 | if (!state->use_set) { |
741 | 1 | return Status::OK(); |
742 | 1 | } |
743 | 9 | is_in = !tmp->is_not_in(); |
744 | | |
745 | 9 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { |
746 | 1 | _eos = true; |
747 | 1 | _scan_dependency->set_ready(); |
748 | 1 | return Status::OK(); |
749 | 1 | } |
750 | 8 | hybrid_set = state->hybrid_set; |
751 | 8 | iter = state->hybrid_set->begin(); |
752 | 8 | } |
753 | | |
754 | 8 | if (iter) { |
755 | 8 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( |
756 | 8 | slot->is_nullable(), range.precision(), range.scale()); |
757 | 8 | auto& temp_range = is_in ? empty_range : range; |
758 | 8 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range |
759 | 8 | : (range.is_fixed_value_range() |
760 | 4 | ? ColumnValueRange<T>::remove_fixed_value_range |
761 | 4 | : ColumnValueRange<T>::empty_function); |
762 | 46 | while (iter->has_next()) { |
763 | | // column in (nullptr) is always false so continue to |
764 | | // dispose next item |
765 | 38 | DCHECK(iter->get_value() != nullptr); |
766 | 38 | const auto* value = iter->get_value(); |
767 | 38 | if constexpr (is_string_type(T)) { |
768 | 0 | const auto* str_value = reinterpret_cast<const StringRef*>(value); |
769 | 0 | RETURN_IF_ERROR(_change_value_range( |
770 | 0 | is_in, temp_range, |
771 | 0 | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, |
772 | 0 | is_in ? "in" : "not_in")); |
773 | 38 | } else { |
774 | 38 | RETURN_IF_ERROR(_change_value_range( |
775 | 38 | is_in, temp_range, |
776 | 38 | Field::create_field<T>( |
777 | 38 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( |
778 | 38 | value)), |
779 | 38 | fn, is_in ? "in" : "not_in")); |
780 | 38 | } |
781 | 38 | iter->next(); |
782 | 38 | } |
783 | 8 | if (is_in) { |
784 | 4 | range.intersection(temp_range); |
785 | 4 | } |
786 | 8 | } |
787 | 8 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( |
788 | 4 | _parent->intermediate_row_desc().get_column_id(slot->id()), |
789 | 4 | slot->col_name(), |
790 | 4 | slot->type()->get_primitive_type() == TYPE_VARIANT |
791 | 4 | ? root->get_child(0)->data_type() |
792 | 4 | : slot->type(), |
793 | 4 | hybrid_set, false) |
794 | 8 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( |
795 | 4 | _parent->intermediate_row_desc().get_column_id(slot->id()), |
796 | 4 | slot->col_name(), |
797 | 4 | slot->type()->get_primitive_type() == TYPE_VARIANT |
798 | 4 | ? root->get_child(0)->data_type() |
799 | 4 | : slot->type(), |
800 | 4 | hybrid_set, false); |
801 | 8 | return Status::OK(); |
802 | 10 | } Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 697 | 6 | PushDownType* pdt) { | 698 | 6 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 699 | 6 | Defer defer = [&]() { | 700 | 6 | if (pred) { | 701 | 6 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 6 | predicates.emplace_back(pred); | 703 | 6 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 6 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 6 | } | 707 | 6 | }; | 708 | | | 709 | 6 | if (slot->get_virtual_column_expr() != nullptr) { | 710 | | // virtual column, do not push down | 711 | 0 | return Status::OK(); | 712 | 0 | } | 713 | | | 714 | 6 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 715 | 6 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 716 | 6 | *pdt = _should_push_down_in_predicate(); | 717 | 6 | if (*pdt == PushDownType::UNACCEPTABLE) { | 718 | 0 | return Status::OK(); | 719 | 0 | } | 720 | 6 | HybridSetBase::IteratorBase* iter = nullptr; | 721 | 6 | auto hybrid_set = root->get_set_func(); | 722 | | | 723 | 6 | auto is_in = false; | 724 | 6 | if (hybrid_set != nullptr) { | 725 | | // runtime filter produce VDirectInPredicate | 726 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 727 | 0 | iter = hybrid_set->begin(); | 728 | 0 | } | 729 | 0 | is_in = true; | 730 | 6 | } else { | 731 | | // normal in predicate | 732 | 6 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 733 | | | 734 | | // begin to push InPredicate value into ColumnValueRange | 735 | 6 | auto* state = reinterpret_cast<InState*>( | 736 | 6 | expr_ctx->fn_context(tmp->fn_context_index()) | 737 | 6 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 738 | | | 739 | | // xx in (col, xx, xx) should not be push down | 740 | 6 | if (!state->use_set) { | 741 | 1 | return Status::OK(); | 742 | 1 | } | 743 | 5 | is_in = !tmp->is_not_in(); | 744 | | | 745 | 5 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 746 | 1 | _eos = true; | 747 | 1 | _scan_dependency->set_ready(); | 748 | 1 | return Status::OK(); | 749 | 1 | } | 750 | 4 | hybrid_set = state->hybrid_set; | 751 | 4 | iter = state->hybrid_set->begin(); | 752 | 4 | } | 753 | | | 754 | 4 | if (iter) { | 755 | 4 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 756 | 4 | slot->is_nullable(), range.precision(), range.scale()); | 757 | 4 | auto& temp_range = is_in ? empty_range : range; | 758 | 4 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 759 | 4 | : (range.is_fixed_value_range() | 760 | 2 | ? ColumnValueRange<T>::remove_fixed_value_range | 761 | 2 | : ColumnValueRange<T>::empty_function); | 762 | 16 | while (iter->has_next()) { | 763 | | // column in (nullptr) is always false so continue to | 764 | | // dispose next item | 765 | 12 | DCHECK(iter->get_value() != nullptr); | 766 | 12 | const auto* value = iter->get_value(); | 767 | | if constexpr (is_string_type(T)) { | 768 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 769 | | RETURN_IF_ERROR(_change_value_range( | 770 | | is_in, temp_range, | 771 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 772 | | is_in ? "in" : "not_in")); | 773 | 12 | } else { | 774 | 12 | RETURN_IF_ERROR(_change_value_range( | 775 | 12 | is_in, temp_range, | 776 | 12 | Field::create_field<T>( | 777 | 12 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 778 | 12 | value)), | 779 | 12 | fn, is_in ? "in" : "not_in")); | 780 | 12 | } | 781 | 12 | iter->next(); | 782 | 12 | } | 783 | 4 | if (is_in) { | 784 | 2 | range.intersection(temp_range); | 785 | 2 | } | 786 | 4 | } | 787 | 4 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 788 | 2 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 789 | 2 | slot->col_name(), | 790 | 2 | slot->type()->get_primitive_type() == TYPE_VARIANT | 791 | 2 | ? root->get_child(0)->data_type() | 792 | 2 | : slot->type(), | 793 | 2 | hybrid_set, false) | 794 | 4 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 795 | 2 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 796 | 2 | slot->col_name(), | 797 | 2 | slot->type()->get_primitive_type() == TYPE_VARIANT | 798 | 2 | ? root->get_child(0)->data_type() | 799 | 2 | : slot->type(), | 800 | 2 | hybrid_set, false); | 801 | 4 | return Status::OK(); | 802 | 6 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 697 | 2 | PushDownType* pdt) { | 698 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 699 | 2 | Defer defer = [&]() { | 700 | 2 | if (pred) { | 701 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 2 | predicates.emplace_back(pred); | 703 | 2 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 2 | } | 707 | 2 | }; | 708 | | | 709 | 2 | if (slot->get_virtual_column_expr() != nullptr) { | 710 | | // virtual column, do not push down | 711 | 0 | return Status::OK(); | 712 | 0 | } | 713 | | | 714 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 715 | 2 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 716 | 2 | *pdt = _should_push_down_in_predicate(); | 717 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 718 | 0 | return Status::OK(); | 719 | 0 | } | 720 | 2 | HybridSetBase::IteratorBase* iter = nullptr; | 721 | 2 | auto hybrid_set = root->get_set_func(); | 722 | | | 723 | 2 | auto is_in = false; | 724 | 2 | if (hybrid_set != nullptr) { | 725 | | // runtime filter produce VDirectInPredicate | 726 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 727 | 0 | iter = hybrid_set->begin(); | 728 | 0 | } | 729 | 0 | is_in = true; | 730 | 2 | } else { | 731 | | // normal in predicate | 732 | 2 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 733 | | | 734 | | // begin to push InPredicate value into ColumnValueRange | 735 | 2 | auto* state = reinterpret_cast<InState*>( | 736 | 2 | expr_ctx->fn_context(tmp->fn_context_index()) | 737 | 2 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 738 | | | 739 | | // xx in (col, xx, xx) should not be push down | 740 | 2 | if (!state->use_set) { | 741 | 0 | return Status::OK(); | 742 | 0 | } | 743 | 2 | is_in = !tmp->is_not_in(); | 744 | | | 745 | 2 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 746 | 0 | _eos = true; | 747 | 0 | _scan_dependency->set_ready(); | 748 | 0 | return Status::OK(); | 749 | 0 | } | 750 | 2 | hybrid_set = state->hybrid_set; | 751 | 2 | iter = state->hybrid_set->begin(); | 752 | 2 | } | 753 | | | 754 | 2 | if (iter) { | 755 | 2 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 756 | 2 | slot->is_nullable(), range.precision(), range.scale()); | 757 | 2 | auto& temp_range = is_in ? empty_range : range; | 758 | 2 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 759 | 2 | : (range.is_fixed_value_range() | 760 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 761 | 1 | : ColumnValueRange<T>::empty_function); | 762 | 22 | while (iter->has_next()) { | 763 | | // column in (nullptr) is always false so continue to | 764 | | // dispose next item | 765 | 20 | DCHECK(iter->get_value() != nullptr); | 766 | 20 | const auto* value = iter->get_value(); | 767 | | if constexpr (is_string_type(T)) { | 768 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 769 | | RETURN_IF_ERROR(_change_value_range( | 770 | | is_in, temp_range, | 771 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 772 | | is_in ? "in" : "not_in")); | 773 | 20 | } else { | 774 | 20 | RETURN_IF_ERROR(_change_value_range( | 775 | 20 | is_in, temp_range, | 776 | 20 | Field::create_field<T>( | 777 | 20 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 778 | 20 | value)), | 779 | 20 | fn, is_in ? "in" : "not_in")); | 780 | 20 | } | 781 | 20 | iter->next(); | 782 | 20 | } | 783 | 2 | if (is_in) { | 784 | 1 | range.intersection(temp_range); | 785 | 1 | } | 786 | 2 | } | 787 | 2 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 788 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 789 | 1 | slot->col_name(), | 790 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 791 | 1 | ? root->get_child(0)->data_type() | 792 | 1 | : slot->type(), | 793 | 1 | hybrid_set, false) | 794 | 2 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 795 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 796 | 1 | slot->col_name(), | 797 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 798 | 1 | ? root->get_child(0)->data_type() | 799 | 1 | : slot->type(), | 800 | 1 | hybrid_set, false); | 801 | 2 | return Status::OK(); | 802 | 2 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 697 | 2 | PushDownType* pdt) { | 698 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 699 | 2 | Defer defer = [&]() { | 700 | 2 | if (pred) { | 701 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 702 | 2 | predicates.emplace_back(pred); | 703 | 2 | } else { | 704 | | // If exception occurs during processing, do not push down | 705 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 706 | 2 | } | 707 | 2 | }; | 708 | | | 709 | 2 | if (slot->get_virtual_column_expr() != nullptr) { | 710 | | // virtual column, do not push down | 711 | 0 | return Status::OK(); | 712 | 0 | } | 713 | | | 714 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 715 | 2 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 716 | 2 | *pdt = _should_push_down_in_predicate(); | 717 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 718 | 0 | return Status::OK(); | 719 | 0 | } | 720 | 2 | HybridSetBase::IteratorBase* iter = nullptr; | 721 | 2 | auto hybrid_set = root->get_set_func(); | 722 | | | 723 | 2 | auto is_in = false; | 724 | 2 | if (hybrid_set != nullptr) { | 725 | | // runtime filter produce VDirectInPredicate | 726 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 727 | 0 | iter = hybrid_set->begin(); | 728 | 0 | } | 729 | 0 | is_in = true; | 730 | 2 | } else { | 731 | | // normal in predicate | 732 | 2 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 733 | | | 734 | | // begin to push InPredicate value into ColumnValueRange | 735 | 2 | auto* state = reinterpret_cast<InState*>( | 736 | 2 | expr_ctx->fn_context(tmp->fn_context_index()) | 737 | 2 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 738 | | | 739 | | // xx in (col, xx, xx) should not be push down | 740 | 2 | if (!state->use_set) { | 741 | 0 | return Status::OK(); | 742 | 0 | } | 743 | 2 | is_in = !tmp->is_not_in(); | 744 | | | 745 | 2 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 746 | 0 | _eos = true; | 747 | 0 | _scan_dependency->set_ready(); | 748 | 0 | return Status::OK(); | 749 | 0 | } | 750 | 2 | hybrid_set = state->hybrid_set; | 751 | 2 | iter = state->hybrid_set->begin(); | 752 | 2 | } | 753 | | | 754 | 2 | if (iter) { | 755 | 2 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 756 | 2 | slot->is_nullable(), range.precision(), range.scale()); | 757 | 2 | auto& temp_range = is_in ? empty_range : range; | 758 | 2 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 759 | 2 | : (range.is_fixed_value_range() | 760 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 761 | 1 | : ColumnValueRange<T>::empty_function); | 762 | 8 | while (iter->has_next()) { | 763 | | // column in (nullptr) is always false so continue to | 764 | | // dispose next item | 765 | 6 | DCHECK(iter->get_value() != nullptr); | 766 | 6 | const auto* value = iter->get_value(); | 767 | | if constexpr (is_string_type(T)) { | 768 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 769 | | RETURN_IF_ERROR(_change_value_range( | 770 | | is_in, temp_range, | 771 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 772 | | is_in ? "in" : "not_in")); | 773 | 6 | } else { | 774 | 6 | RETURN_IF_ERROR(_change_value_range( | 775 | 6 | is_in, temp_range, | 776 | 6 | Field::create_field<T>( | 777 | 6 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 778 | 6 | value)), | 779 | 6 | fn, is_in ? "in" : "not_in")); | 780 | 6 | } | 781 | 6 | iter->next(); | 782 | 6 | } | 783 | 2 | if (is_in) { | 784 | 1 | range.intersection(temp_range); | 785 | 1 | } | 786 | 2 | } | 787 | 2 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 788 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 789 | 1 | slot->col_name(), | 790 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 791 | 1 | ? root->get_child(0)->data_type() | 792 | 1 | : slot->type(), | 793 | 1 | hybrid_set, false) | 794 | 2 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 795 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 796 | 1 | slot->col_name(), | 797 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 798 | 1 | ? root->get_child(0)->data_type() | 799 | 1 | : slot->type(), | 800 | 1 | hybrid_set, false); | 801 | 2 | return Status::OK(); | 802 | 2 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase23_normalize_in_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE |
803 | | |
804 | | template <PrimitiveType T> |
805 | | Status ScanLocalStateBase::_normalize_binary_predicate( |
806 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
807 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
808 | 85 | PushDownType* pdt) { |
809 | 85 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
810 | 85 | Defer defer = [&]() { |
811 | 85 | if (pred) { |
812 | 84 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
813 | 84 | predicates.emplace_back(pred); |
814 | 84 | } else { |
815 | | // If exception occurs during processing, do not push down |
816 | 1 | *pdt = PushDownType::UNACCEPTABLE; |
817 | 1 | } |
818 | 85 | }; Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 810 | 7 | Defer defer = [&]() { | 811 | 7 | if (pred) { | 812 | 6 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 6 | predicates.emplace_back(pred); | 814 | 6 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 1 | } | 818 | 7 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 810 | 60 | Defer defer = [&]() { | 811 | 60 | if (pred) { | 812 | 60 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 60 | predicates.emplace_back(pred); | 814 | 60 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 0 | } | 818 | 60 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 810 | 18 | Defer defer = [&]() { | 811 | 18 | if (pred) { | 812 | 18 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 18 | predicates.emplace_back(pred); | 814 | 18 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 0 | } | 818 | 18 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv |
819 | | |
820 | 85 | if (slot->get_virtual_column_expr() != nullptr) { |
821 | | // virtual column, do not push down |
822 | 0 | return Status::OK(); |
823 | 0 | } |
824 | | |
825 | 85 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
826 | 85 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); |
827 | 85 | DCHECK(root->get_num_children() == 2); |
828 | 85 | Field value; |
829 | 85 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, |
830 | 85 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); |
831 | 85 | if (*pdt == PushDownType::UNACCEPTABLE) { |
832 | 0 | return Status::OK(); |
833 | 0 | } |
834 | 85 | const std::string& function_name = |
835 | 85 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; |
836 | 85 | auto op = to_olap_filter_type(function_name); |
837 | 85 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; |
838 | 85 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( |
839 | 85 | slot->is_nullable(), range.precision(), range.scale()); |
840 | 85 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; |
841 | 85 | if (value.get_type() != TYPE_NULL) { |
842 | 84 | switch (op) { |
843 | 16 | case SQLFilterOp::FILTER_EQ: |
844 | 16 | pred = create_comparison_predicate<PredicateType::EQ>( |
845 | 16 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
846 | 16 | slot->type()->get_primitive_type() == TYPE_VARIANT |
847 | 16 | ? root->get_child(0)->data_type() |
848 | 16 | : slot->type(), |
849 | 16 | value, false); |
850 | 16 | break; |
851 | 14 | case SQLFilterOp::FILTER_NE: |
852 | 14 | pred = create_comparison_predicate<PredicateType::NE>( |
853 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
854 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
855 | 14 | ? root->get_child(0)->data_type() |
856 | 14 | : slot->type(), |
857 | 14 | value, false); |
858 | 14 | break; |
859 | 13 | case SQLFilterOp::FILTER_LESS: |
860 | 13 | pred = create_comparison_predicate<PredicateType::LT>( |
861 | 13 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
862 | 13 | slot->type()->get_primitive_type() == TYPE_VARIANT |
863 | 13 | ? root->get_child(0)->data_type() |
864 | 13 | : slot->type(), |
865 | 13 | value, false); |
866 | 13 | break; |
867 | 13 | case SQLFilterOp::FILTER_LARGER: |
868 | 13 | pred = create_comparison_predicate<PredicateType::GT>( |
869 | 13 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
870 | 13 | slot->type()->get_primitive_type() == TYPE_VARIANT |
871 | 13 | ? root->get_child(0)->data_type() |
872 | 13 | : slot->type(), |
873 | 13 | value, false); |
874 | 13 | break; |
875 | 14 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: |
876 | 14 | pred = create_comparison_predicate<PredicateType::LE>( |
877 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
878 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
879 | 14 | ? root->get_child(0)->data_type() |
880 | 14 | : slot->type(), |
881 | 14 | value, false); |
882 | 14 | break; |
883 | 14 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: |
884 | 14 | pred = create_comparison_predicate<PredicateType::GE>( |
885 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
886 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
887 | 14 | ? root->get_child(0)->data_type() |
888 | 14 | : slot->type(), |
889 | 14 | value, false); |
890 | 14 | break; |
891 | 0 | default: |
892 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); |
893 | 84 | } |
894 | | |
895 | 84 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range |
896 | 84 | : op == SQLFilterOp::FILTER_NE |
897 | 68 | ? (range.is_fixed_value_range() |
898 | 14 | ? ColumnValueRange<T>::remove_fixed_value_range |
899 | 14 | : ColumnValueRange<T>::empty_function) |
900 | 68 | : ColumnValueRange<T>::add_value_range; |
901 | 84 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); |
902 | 84 | if (op == SQLFilterOp::FILTER_EQ) { |
903 | 16 | range.intersection(temp_range); |
904 | 16 | } |
905 | 84 | } else { |
906 | 1 | *pdt = PushDownType::UNACCEPTABLE; |
907 | 1 | _eos = true; |
908 | 1 | _scan_dependency->set_ready(); |
909 | 1 | } |
910 | | |
911 | 85 | return Status::OK(); |
912 | 85 | } Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 808 | 7 | PushDownType* pdt) { | 809 | 7 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 810 | 7 | Defer defer = [&]() { | 811 | 7 | if (pred) { | 812 | 7 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 7 | predicates.emplace_back(pred); | 814 | 7 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 7 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 7 | } | 818 | 7 | }; | 819 | | | 820 | 7 | if (slot->get_virtual_column_expr() != nullptr) { | 821 | | // virtual column, do not push down | 822 | 0 | return Status::OK(); | 823 | 0 | } | 824 | | | 825 | 7 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 826 | 7 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 827 | 7 | DCHECK(root->get_num_children() == 2); | 828 | 7 | Field value; | 829 | 7 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 830 | 7 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 831 | 7 | if (*pdt == PushDownType::UNACCEPTABLE) { | 832 | 0 | return Status::OK(); | 833 | 0 | } | 834 | 7 | const std::string& function_name = | 835 | 7 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 836 | 7 | auto op = to_olap_filter_type(function_name); | 837 | 7 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 838 | 7 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 839 | 7 | slot->is_nullable(), range.precision(), range.scale()); | 840 | 7 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 841 | 7 | if (value.get_type() != TYPE_NULL) { | 842 | 6 | switch (op) { | 843 | 3 | case SQLFilterOp::FILTER_EQ: | 844 | 3 | pred = create_comparison_predicate<PredicateType::EQ>( | 845 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 846 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 847 | 3 | ? root->get_child(0)->data_type() | 848 | 3 | : slot->type(), | 849 | 3 | value, false); | 850 | 3 | break; | 851 | 1 | case SQLFilterOp::FILTER_NE: | 852 | 1 | pred = create_comparison_predicate<PredicateType::NE>( | 853 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 854 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 855 | 1 | ? root->get_child(0)->data_type() | 856 | 1 | : slot->type(), | 857 | 1 | value, false); | 858 | 1 | break; | 859 | 0 | case SQLFilterOp::FILTER_LESS: | 860 | 0 | pred = create_comparison_predicate<PredicateType::LT>( | 861 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 862 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT | 863 | 0 | ? root->get_child(0)->data_type() | 864 | 0 | : slot->type(), | 865 | 0 | value, false); | 866 | 0 | break; | 867 | 0 | case SQLFilterOp::FILTER_LARGER: | 868 | 0 | pred = create_comparison_predicate<PredicateType::GT>( | 869 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 870 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT | 871 | 0 | ? root->get_child(0)->data_type() | 872 | 0 | : slot->type(), | 873 | 0 | value, false); | 874 | 0 | break; | 875 | 1 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 876 | 1 | pred = create_comparison_predicate<PredicateType::LE>( | 877 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 878 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 879 | 1 | ? root->get_child(0)->data_type() | 880 | 1 | : slot->type(), | 881 | 1 | value, false); | 882 | 1 | break; | 883 | 1 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 884 | 1 | pred = create_comparison_predicate<PredicateType::GE>( | 885 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 886 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 887 | 1 | ? root->get_child(0)->data_type() | 888 | 1 | : slot->type(), | 889 | 1 | value, false); | 890 | 1 | break; | 891 | 0 | default: | 892 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 893 | 6 | } | 894 | | | 895 | 6 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 896 | 6 | : op == SQLFilterOp::FILTER_NE | 897 | 3 | ? (range.is_fixed_value_range() | 898 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 899 | 1 | : ColumnValueRange<T>::empty_function) | 900 | 3 | : ColumnValueRange<T>::add_value_range; | 901 | 6 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 902 | 6 | if (op == SQLFilterOp::FILTER_EQ) { | 903 | 3 | range.intersection(temp_range); | 904 | 3 | } | 905 | 6 | } else { | 906 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 907 | 1 | _eos = true; | 908 | 1 | _scan_dependency->set_ready(); | 909 | 1 | } | 910 | | | 911 | 7 | return Status::OK(); | 912 | 7 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 808 | 60 | PushDownType* pdt) { | 809 | 60 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 810 | 60 | Defer defer = [&]() { | 811 | 60 | if (pred) { | 812 | 60 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 60 | predicates.emplace_back(pred); | 814 | 60 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 60 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 60 | } | 818 | 60 | }; | 819 | | | 820 | 60 | if (slot->get_virtual_column_expr() != nullptr) { | 821 | | // virtual column, do not push down | 822 | 0 | return Status::OK(); | 823 | 0 | } | 824 | | | 825 | 60 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 826 | 60 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 827 | 60 | DCHECK(root->get_num_children() == 2); | 828 | 60 | Field value; | 829 | 60 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 830 | 60 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 831 | 60 | if (*pdt == PushDownType::UNACCEPTABLE) { | 832 | 0 | return Status::OK(); | 833 | 0 | } | 834 | 60 | const std::string& function_name = | 835 | 60 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 836 | 60 | auto op = to_olap_filter_type(function_name); | 837 | 60 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 838 | 60 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 839 | 60 | slot->is_nullable(), range.precision(), range.scale()); | 840 | 60 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 841 | 60 | if (value.get_type() != TYPE_NULL) { | 842 | 60 | switch (op) { | 843 | 10 | case SQLFilterOp::FILTER_EQ: | 844 | 10 | pred = create_comparison_predicate<PredicateType::EQ>( | 845 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 846 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 847 | 10 | ? root->get_child(0)->data_type() | 848 | 10 | : slot->type(), | 849 | 10 | value, false); | 850 | 10 | break; | 851 | 10 | case SQLFilterOp::FILTER_NE: | 852 | 10 | pred = create_comparison_predicate<PredicateType::NE>( | 853 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 854 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 855 | 10 | ? root->get_child(0)->data_type() | 856 | 10 | : slot->type(), | 857 | 10 | value, false); | 858 | 10 | break; | 859 | 10 | case SQLFilterOp::FILTER_LESS: | 860 | 10 | pred = create_comparison_predicate<PredicateType::LT>( | 861 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 862 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 863 | 10 | ? root->get_child(0)->data_type() | 864 | 10 | : slot->type(), | 865 | 10 | value, false); | 866 | 10 | break; | 867 | 10 | case SQLFilterOp::FILTER_LARGER: | 868 | 10 | pred = create_comparison_predicate<PredicateType::GT>( | 869 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 870 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 871 | 10 | ? root->get_child(0)->data_type() | 872 | 10 | : slot->type(), | 873 | 10 | value, false); | 874 | 10 | break; | 875 | 10 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 876 | 10 | pred = create_comparison_predicate<PredicateType::LE>( | 877 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 878 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 879 | 10 | ? root->get_child(0)->data_type() | 880 | 10 | : slot->type(), | 881 | 10 | value, false); | 882 | 10 | break; | 883 | 10 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 884 | 10 | pred = create_comparison_predicate<PredicateType::GE>( | 885 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 886 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 887 | 10 | ? root->get_child(0)->data_type() | 888 | 10 | : slot->type(), | 889 | 10 | value, false); | 890 | 10 | break; | 891 | 0 | default: | 892 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 893 | 60 | } | 894 | | | 895 | 60 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 896 | 60 | : op == SQLFilterOp::FILTER_NE | 897 | 50 | ? (range.is_fixed_value_range() | 898 | 10 | ? ColumnValueRange<T>::remove_fixed_value_range | 899 | 10 | : ColumnValueRange<T>::empty_function) | 900 | 50 | : ColumnValueRange<T>::add_value_range; | 901 | 60 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 902 | 60 | if (op == SQLFilterOp::FILTER_EQ) { | 903 | 10 | range.intersection(temp_range); | 904 | 10 | } | 905 | 60 | } else { | 906 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 907 | 0 | _eos = true; | 908 | 0 | _scan_dependency->set_ready(); | 909 | 0 | } | 910 | | | 911 | 60 | return Status::OK(); | 912 | 60 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 808 | 18 | PushDownType* pdt) { | 809 | 18 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 810 | 18 | Defer defer = [&]() { | 811 | 18 | if (pred) { | 812 | 18 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 813 | 18 | predicates.emplace_back(pred); | 814 | 18 | } else { | 815 | | // If exception occurs during processing, do not push down | 816 | 18 | *pdt = PushDownType::UNACCEPTABLE; | 817 | 18 | } | 818 | 18 | }; | 819 | | | 820 | 18 | if (slot->get_virtual_column_expr() != nullptr) { | 821 | | // virtual column, do not push down | 822 | 0 | return Status::OK(); | 823 | 0 | } | 824 | | | 825 | 18 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 826 | 18 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 827 | 18 | DCHECK(root->get_num_children() == 2); | 828 | 18 | Field value; | 829 | 18 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 830 | 18 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 831 | 18 | if (*pdt == PushDownType::UNACCEPTABLE) { | 832 | 0 | return Status::OK(); | 833 | 0 | } | 834 | 18 | const std::string& function_name = | 835 | 18 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 836 | 18 | auto op = to_olap_filter_type(function_name); | 837 | 18 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 838 | 18 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 839 | 18 | slot->is_nullable(), range.precision(), range.scale()); | 840 | 18 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 841 | 18 | if (value.get_type() != TYPE_NULL) { | 842 | 18 | switch (op) { | 843 | 3 | case SQLFilterOp::FILTER_EQ: | 844 | 3 | pred = create_comparison_predicate<PredicateType::EQ>( | 845 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 846 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 847 | 3 | ? root->get_child(0)->data_type() | 848 | 3 | : slot->type(), | 849 | 3 | value, false); | 850 | 3 | break; | 851 | 3 | case SQLFilterOp::FILTER_NE: | 852 | 3 | pred = create_comparison_predicate<PredicateType::NE>( | 853 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 854 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 855 | 3 | ? root->get_child(0)->data_type() | 856 | 3 | : slot->type(), | 857 | 3 | value, false); | 858 | 3 | break; | 859 | 3 | case SQLFilterOp::FILTER_LESS: | 860 | 3 | pred = create_comparison_predicate<PredicateType::LT>( | 861 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 862 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 863 | 3 | ? root->get_child(0)->data_type() | 864 | 3 | : slot->type(), | 865 | 3 | value, false); | 866 | 3 | break; | 867 | 3 | case SQLFilterOp::FILTER_LARGER: | 868 | 3 | pred = create_comparison_predicate<PredicateType::GT>( | 869 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 870 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 871 | 3 | ? root->get_child(0)->data_type() | 872 | 3 | : slot->type(), | 873 | 3 | value, false); | 874 | 3 | break; | 875 | 3 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 876 | 3 | pred = create_comparison_predicate<PredicateType::LE>( | 877 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 878 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 879 | 3 | ? root->get_child(0)->data_type() | 880 | 3 | : slot->type(), | 881 | 3 | value, false); | 882 | 3 | break; | 883 | 3 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 884 | 3 | pred = create_comparison_predicate<PredicateType::GE>( | 885 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 886 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 887 | 3 | ? root->get_child(0)->data_type() | 888 | 3 | : slot->type(), | 889 | 3 | value, false); | 890 | 3 | break; | 891 | 0 | default: | 892 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 893 | 18 | } | 894 | | | 895 | 18 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 896 | 18 | : op == SQLFilterOp::FILTER_NE | 897 | 15 | ? (range.is_fixed_value_range() | 898 | 3 | ? ColumnValueRange<T>::remove_fixed_value_range | 899 | 3 | : ColumnValueRange<T>::empty_function) | 900 | 15 | : ColumnValueRange<T>::add_value_range; | 901 | 18 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 902 | 18 | if (op == SQLFilterOp::FILTER_EQ) { | 903 | 3 | range.intersection(temp_range); | 904 | 3 | } | 905 | 18 | } else { | 906 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 907 | 0 | _eos = true; | 908 | 0 | _scan_dependency->set_ready(); | 909 | 0 | } | 910 | | | 911 | 18 | return Status::OK(); | 912 | 18 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase27_normalize_binary_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE |
913 | | |
914 | | template <PrimitiveType PrimitiveType, typename ChangeFixedValueRangeFunc> |
915 | | Status ScanLocalStateBase::_change_value_range(bool is_equal_op, |
916 | | ColumnValueRange<PrimitiveType>& temp_range, |
917 | | const Field& value, |
918 | | const ChangeFixedValueRangeFunc& func, |
919 | 122 | const std::string& fn_name) { |
920 | 122 | if constexpr (PrimitiveType == TYPE_DATE) { |
921 | 0 | auto tmp_value = value.template get<TYPE_DATE>(); |
922 | 0 | if (is_equal_op) { |
923 | 0 | if (!tmp_value.check_loss_accuracy_cast_to_date()) { |
924 | 0 | func(temp_range, to_olap_filter_type(fn_name), tmp_value); |
925 | 0 | } |
926 | 0 | } else { |
927 | 0 | if (tmp_value.check_loss_accuracy_cast_to_date()) { |
928 | 0 | if (fn_name == "lt" || fn_name == "ge") { |
929 | 0 | ++tmp_value; |
930 | 0 | } |
931 | 0 | } |
932 | 0 | func(temp_range, to_olap_filter_type(fn_name), tmp_value); |
933 | 0 | } |
934 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || |
935 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || |
936 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || |
937 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || |
938 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || |
939 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || |
940 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || |
941 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || |
942 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || |
943 | 122 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { |
944 | 122 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); |
945 | | } else { |
946 | | static_assert(always_false_v<PrimitiveType>); |
947 | | } |
948 | 122 | return Status::OK(); |
949 | 122 | } Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE3EPFvRNS_16ColumnValueRangeILS2_3EEENS_11SQLFilterOpERKaEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE4EPFvRNS_16ColumnValueRangeILS2_4EEENS_11SQLFilterOpERKsEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE5EPFvRNS_16ColumnValueRangeILS2_5EEENS_11SQLFilterOpERKiEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE6EPFvRNS_16ColumnValueRangeILS2_6EEENS_11SQLFilterOpERKlEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Line | Count | Source | 919 | 18 | const std::string& fn_name) { | 920 | | if constexpr (PrimitiveType == TYPE_DATE) { | 921 | | auto tmp_value = value.template get<TYPE_DATE>(); | 922 | | if (is_equal_op) { | 923 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 924 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 925 | | } | 926 | | } else { | 927 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 928 | | if (fn_name == "lt" || fn_name == "ge") { | 929 | | ++tmp_value; | 930 | | } | 931 | | } | 932 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 933 | | } | 934 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 935 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 936 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 937 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 938 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 939 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 940 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 941 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 942 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 943 | 18 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 944 | 18 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 945 | | } else { | 946 | | static_assert(always_false_v<PrimitiveType>); | 947 | | } | 948 | 18 | return Status::OK(); | 949 | 18 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE7EPFvRNS_16ColumnValueRangeILS2_7EEENS_11SQLFilterOpERKnEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE8EPFvRNS_16ColumnValueRangeILS2_8EEENS_11SQLFilterOpERKfEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE9EPFvRNS_16ColumnValueRangeILS2_9EEENS_11SQLFilterOpERKdEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Line | Count | Source | 919 | 80 | const std::string& fn_name) { | 920 | | if constexpr (PrimitiveType == TYPE_DATE) { | 921 | | auto tmp_value = value.template get<TYPE_DATE>(); | 922 | | if (is_equal_op) { | 923 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 924 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 925 | | } | 926 | | } else { | 927 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 928 | | if (fn_name == "lt" || fn_name == "ge") { | 929 | | ++tmp_value; | 930 | | } | 931 | | } | 932 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 933 | | } | 934 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 935 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 936 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 937 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 938 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 939 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 940 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 941 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 942 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 943 | 80 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 944 | 80 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 945 | | } else { | 946 | | static_assert(always_false_v<PrimitiveType>); | 947 | | } | 948 | 80 | return Status::OK(); | 949 | 80 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE36EPFvRNS_16ColumnValueRangeILS2_36EEENS_11SQLFilterOpERKjEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE37EPFvRNS_16ColumnValueRangeILS2_37EEENS_11SQLFilterOpERKoEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE15EPFvRNS_16ColumnValueRangeILS2_15EEENS_11SQLFilterOpERKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_SE_ Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE10EPFvRNS_16ColumnValueRangeILS2_10EEENS_11SQLFilterOpERKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_SE_ Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE23EPFvRNS_16ColumnValueRangeILS2_23EEENS_11SQLFilterOpERKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_SE_ Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE11EPFvRNS_16ColumnValueRangeILS2_11EEENS_11SQLFilterOpERKNS_16VecDateTimeValueEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE25EPFvRNS_16ColumnValueRangeILS2_25EEENS_11SQLFilterOpERKNS_11DateV2ValueINS_15DateV2ValueTypeEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE12EPFvRNS_16ColumnValueRangeILS2_12EEENS_11SQLFilterOpERKNS_16VecDateTimeValueEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE26EPFvRNS_16ColumnValueRangeILS2_26EEENS_11SQLFilterOpERKNS_11DateV2ValueINS_19DateTimeV2ValueTypeEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE42EPFvRNS_16ColumnValueRangeILS2_42EEENS_11SQLFilterOpERKNS_16TimestampTzValueEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Line | Count | Source | 919 | 24 | const std::string& fn_name) { | 920 | | if constexpr (PrimitiveType == TYPE_DATE) { | 921 | | auto tmp_value = value.template get<TYPE_DATE>(); | 922 | | if (is_equal_op) { | 923 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 924 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 925 | | } | 926 | | } else { | 927 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 928 | | if (fn_name == "lt" || fn_name == "ge") { | 929 | | ++tmp_value; | 930 | | } | 931 | | } | 932 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 933 | | } | 934 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 935 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 936 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 937 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 938 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 939 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 940 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 941 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 942 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 943 | 24 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 944 | 24 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 945 | | } else { | 946 | | static_assert(always_false_v<PrimitiveType>); | 947 | | } | 948 | 24 | return Status::OK(); | 949 | 24 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE20EPFvRNS_16ColumnValueRangeILS2_20EEENS_11SQLFilterOpERKNS_14DecimalV2ValueEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE2EPFvRNS_16ColumnValueRangeILS2_2EEENS_11SQLFilterOpERKhEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE28EPFvRNS_16ColumnValueRangeILS2_28EEENS_11SQLFilterOpERKNS_7DecimalIiEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE29EPFvRNS_16ColumnValueRangeILS2_29EEENS_11SQLFilterOpERKNS_7DecimalIlEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE30EPFvRNS_16ColumnValueRangeILS2_30EEENS_11SQLFilterOpERKNS_12Decimal128V3EEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase19_change_value_rangeILNS_13PrimitiveTypeE35EPFvRNS_16ColumnValueRangeILS2_35EEENS_11SQLFilterOpERKNS_7DecimalIN4wide7integerILm256EiEEEEEEENS_6StatusEbRNS3_IXT_EEERKNS_5FieldERKT0_RKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE |
950 | | |
951 | | template <PrimitiveType T> |
952 | | Status ScanLocalStateBase::_normalize_is_null_predicate( |
953 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
954 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
955 | 4 | PushDownType* pdt) { |
956 | 4 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
957 | 4 | Defer defer = [&]() { |
958 | 4 | if (pred) { |
959 | 4 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
960 | 4 | predicates.emplace_back(pred); |
961 | 4 | } else { |
962 | | // If exception occurs during processing, do not push down |
963 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
964 | 0 | } |
965 | 4 | }; Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 957 | 2 | Defer defer = [&]() { | 958 | 2 | if (pred) { | 959 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 2 | predicates.emplace_back(pred); | 961 | 2 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 0 | } | 965 | 2 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 957 | 1 | Defer defer = [&]() { | 958 | 1 | if (pred) { | 959 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 1 | predicates.emplace_back(pred); | 961 | 1 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 0 | } | 965 | 1 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Line | Count | Source | 957 | 1 | Defer defer = [&]() { | 958 | 1 | if (pred) { | 959 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 1 | predicates.emplace_back(pred); | 961 | 1 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 0 | } | 965 | 1 | }; |
Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv Unexecuted instantiation: _ZZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeEENKUlvE_clEv |
966 | 4 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
967 | 4 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); |
968 | 4 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { |
969 | 4 | *pdt = _should_push_down_is_null_predicate(fn_call); |
970 | 4 | } else { |
971 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
972 | 0 | } |
973 | | |
974 | 4 | if (*pdt == PushDownType::UNACCEPTABLE) { |
975 | 0 | return Status::OK(); |
976 | 0 | } |
977 | | |
978 | 4 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); |
979 | 4 | if (fn_call->fn().name.function_name == "is_null_pred") { |
980 | 1 | pred = NullPredicate::create_shared( |
981 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, |
982 | 1 | T); |
983 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( |
984 | 1 | slot->is_nullable(), range.precision(), range.scale()); |
985 | 1 | temp_range.set_contain_null(true); |
986 | 1 | range.intersection(temp_range); |
987 | 3 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { |
988 | 3 | pred = NullPredicate::create_shared( |
989 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, |
990 | 3 | T); |
991 | 3 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( |
992 | 3 | slot->is_nullable(), range.precision(), range.scale()); |
993 | 3 | temp_range.set_contain_null(false); |
994 | 3 | range.intersection(temp_range); |
995 | 3 | } |
996 | 4 | return Status::OK(); |
997 | 4 | } Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE3EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE4EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE5EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE6EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 955 | 2 | PushDownType* pdt) { | 956 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 957 | 2 | Defer defer = [&]() { | 958 | 2 | if (pred) { | 959 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 2 | predicates.emplace_back(pred); | 961 | 2 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 2 | } | 965 | 2 | }; | 966 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 967 | 2 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 968 | 2 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 969 | 2 | *pdt = _should_push_down_is_null_predicate(fn_call); | 970 | 2 | } else { | 971 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 972 | 0 | } | 973 | | | 974 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 975 | 0 | return Status::OK(); | 976 | 0 | } | 977 | | | 978 | 2 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 979 | 2 | if (fn_call->fn().name.function_name == "is_null_pred") { | 980 | 1 | pred = NullPredicate::create_shared( | 981 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 982 | 1 | T); | 983 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 984 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 985 | 1 | temp_range.set_contain_null(true); | 986 | 1 | range.intersection(temp_range); | 987 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 988 | 1 | pred = NullPredicate::create_shared( | 989 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 990 | 1 | T); | 991 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 992 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 993 | 1 | temp_range.set_contain_null(false); | 994 | 1 | range.intersection(temp_range); | 995 | 1 | } | 996 | 2 | return Status::OK(); | 997 | 2 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE7EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE8EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE9EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 955 | 1 | PushDownType* pdt) { | 956 | 1 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 957 | 1 | Defer defer = [&]() { | 958 | 1 | if (pred) { | 959 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 1 | predicates.emplace_back(pred); | 961 | 1 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 1 | } | 965 | 1 | }; | 966 | 1 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 967 | 1 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 968 | 1 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 969 | 1 | *pdt = _should_push_down_is_null_predicate(fn_call); | 970 | 1 | } else { | 971 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 972 | 0 | } | 973 | | | 974 | 1 | if (*pdt == PushDownType::UNACCEPTABLE) { | 975 | 0 | return Status::OK(); | 976 | 0 | } | 977 | | | 978 | 1 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 979 | 1 | if (fn_call->fn().name.function_name == "is_null_pred") { | 980 | 0 | pred = NullPredicate::create_shared( | 981 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 982 | 0 | T); | 983 | 0 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 984 | 0 | slot->is_nullable(), range.precision(), range.scale()); | 985 | 0 | temp_range.set_contain_null(true); | 986 | 0 | range.intersection(temp_range); | 987 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 988 | 1 | pred = NullPredicate::create_shared( | 989 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 990 | 1 | T); | 991 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 992 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 993 | 1 | temp_range.set_contain_null(false); | 994 | 1 | range.intersection(temp_range); | 995 | 1 | } | 996 | 1 | return Status::OK(); | 997 | 1 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE36EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE37EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE15EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE10EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE23EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE11EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE25EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE12EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE26EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE42EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Line | Count | Source | 955 | 1 | PushDownType* pdt) { | 956 | 1 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 957 | 1 | Defer defer = [&]() { | 958 | 1 | if (pred) { | 959 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 960 | 1 | predicates.emplace_back(pred); | 961 | 1 | } else { | 962 | | // If exception occurs during processing, do not push down | 963 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 964 | 1 | } | 965 | 1 | }; | 966 | 1 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 967 | 1 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 968 | 1 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 969 | 1 | *pdt = _should_push_down_is_null_predicate(fn_call); | 970 | 1 | } else { | 971 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 972 | 0 | } | 973 | | | 974 | 1 | if (*pdt == PushDownType::UNACCEPTABLE) { | 975 | 0 | return Status::OK(); | 976 | 0 | } | 977 | | | 978 | 1 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 979 | 1 | if (fn_call->fn().name.function_name == "is_null_pred") { | 980 | 0 | pred = NullPredicate::create_shared( | 981 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 982 | 0 | T); | 983 | 0 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 984 | 0 | slot->is_nullable(), range.precision(), range.scale()); | 985 | 0 | temp_range.set_contain_null(true); | 986 | 0 | range.intersection(temp_range); | 987 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 988 | 1 | pred = NullPredicate::create_shared( | 989 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 990 | 1 | T); | 991 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 992 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 993 | 1 | temp_range.set_contain_null(false); | 994 | 1 | range.intersection(temp_range); | 995 | 1 | } | 996 | 1 | return Status::OK(); | 997 | 1 | } |
Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE20EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE2EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE28EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE29EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE30EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE Unexecuted instantiation: _ZN5doris18ScanLocalStateBase28_normalize_is_null_predicateILNS_13PrimitiveTypeE35EEENS_6StatusEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEEPNS_14SlotDescriptorERSt6vectorIS6_INS_15ColumnPredicateEESaISF_EERNS_16ColumnValueRangeIXT_EEEPNS_12PushDownTypeE |
998 | | |
999 | | template <typename Derived> |
1000 | 0 | Status ScanLocalState<Derived>::_prepare_scanners() { |
1001 | 0 | std::list<ScannerSPtr> scanners; |
1002 | 0 | RETURN_IF_ERROR(_init_scanners(&scanners)); |
1003 | | // Init scanner wrapper |
1004 | 0 | for (auto it = scanners.begin(); it != scanners.end(); ++it) { |
1005 | 0 | _scanners.emplace_back(std::make_shared<ScannerDelegate>(*it)); |
1006 | 0 | } |
1007 | 0 | if (scanners.empty()) { |
1008 | 0 | _eos = true; |
1009 | 0 | _scan_dependency->set_always_ready(); |
1010 | 0 | } else { |
1011 | 0 | COUNTER_SET(_num_scanners, static_cast<int64_t>(scanners.size())); |
1012 | 0 | RETURN_IF_ERROR(_start_scanners(_scanners)); |
1013 | 0 | } |
1014 | 0 | return Status::OK(); |
1015 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE17_prepare_scannersEv |
1016 | | |
1017 | | template <typename Derived> |
1018 | | Status ScanLocalState<Derived>::_start_scanners( |
1019 | 0 | const std::list<std::shared_ptr<ScannerDelegate>>& scanners) { |
1020 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1021 | 0 | _scanner_ctx.store(ScannerContext::create_shared( |
1022 | 0 | state(), this, p._output_tuple_desc, p.output_row_descriptor(), scanners, p.limit(), |
1023 | 0 | _scan_dependency, &p._shared_scan_limit, p._mem_arb, p._mem_limiter, _instance_idx, |
1024 | 0 | _state->get_query_ctx()->get_query_options().__isset.enable_adaptive_scan && |
1025 | 0 | _state->get_query_ctx()->get_query_options().enable_adaptive_scan |
1026 | 0 | #ifdef BE_TEST |
1027 | 0 | , |
1028 | 0 | max_scanners_concurrency(state()) |
1029 | 0 | #endif |
1030 | 0 | )); |
1031 | 0 | return Status::OK(); |
1032 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE15_start_scannersERKNSt7__cxx114listISt10shared_ptrINS_15ScannerDelegateEESaIS7_EEE |
1033 | | |
1034 | | template <typename Derived> |
1035 | 0 | const TupleDescriptor* ScanLocalState<Derived>::input_tuple_desc() const { |
1036 | 0 | return _parent->cast<typename Derived::Parent>()._input_tuple_desc; |
1037 | 0 | } Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE16input_tuple_descEv |
1038 | | template <typename Derived> |
1039 | 19 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { |
1040 | 19 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; |
1041 | 19 | } _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE17output_tuple_descEv Line | Count | Source | 1039 | 15 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { | 1040 | 15 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; | 1041 | 15 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17output_tuple_descEv _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE17output_tuple_descEv Line | Count | Source | 1039 | 2 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { | 1040 | 2 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; | 1041 | 2 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE17output_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17output_tuple_descEv _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE17output_tuple_descEv Line | Count | Source | 1039 | 2 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { | 1040 | 2 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; | 1041 | 2 | } |
|
1042 | | |
1043 | | template <typename Derived> |
1044 | 1 | TPushAggOp::type ScanLocalState<Derived>::get_push_down_agg_type() { |
1045 | 1 | return _parent->cast<typename Derived::Parent>()._push_down_agg_type; |
1046 | 1 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE22get_push_down_agg_typeEv _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE22get_push_down_agg_typeEv Line | Count | Source | 1044 | 1 | TPushAggOp::type ScanLocalState<Derived>::get_push_down_agg_type() { | 1045 | 1 | return _parent->cast<typename Derived::Parent>()._push_down_agg_type; | 1046 | 1 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE22get_push_down_agg_typeEv |
1047 | | |
1048 | | template <typename Derived> |
1049 | 0 | int64_t ScanLocalState<Derived>::limit_per_scanner() { |
1050 | 0 | return _parent->cast<typename Derived::Parent>()._limit_per_scanner; |
1051 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE17limit_per_scannerEv |
1052 | | |
1053 | | template <typename Derived> |
1054 | 4 | std::atomic<int64_t>* ScanLocalState<Derived>::shared_scan_limit_ptr() { |
1055 | 4 | auto* p = &_parent->cast<typename Derived::Parent>()._shared_scan_limit; |
1056 | | // -1 means "no SQL LIMIT" — return nullptr so callers naturally skip |
1057 | | // all limit logic. |
1058 | 4 | return p->load(std::memory_order_relaxed) < 0 ? nullptr : p; |
1059 | 4 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE21shared_scan_limit_ptrEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE21shared_scan_limit_ptrEv _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE21shared_scan_limit_ptrEv Line | Count | Source | 1054 | 2 | std::atomic<int64_t>* ScanLocalState<Derived>::shared_scan_limit_ptr() { | 1055 | 2 | auto* p = &_parent->cast<typename Derived::Parent>()._shared_scan_limit; | 1056 | | // -1 means "no SQL LIMIT" — return nullptr so callers naturally skip | 1057 | | // all limit logic. | 1058 | 2 | return p->load(std::memory_order_relaxed) < 0 ? nullptr : p; | 1059 | 2 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE21shared_scan_limit_ptrEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE21shared_scan_limit_ptrEv _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE21shared_scan_limit_ptrEv Line | Count | Source | 1054 | 2 | std::atomic<int64_t>* ScanLocalState<Derived>::shared_scan_limit_ptr() { | 1055 | 2 | auto* p = &_parent->cast<typename Derived::Parent>()._shared_scan_limit; | 1056 | | // -1 means "no SQL LIMIT" — return nullptr so callers naturally skip | 1057 | | // all limit logic. | 1058 | 2 | return p->load(std::memory_order_relaxed) < 0 ? nullptr : p; | 1059 | 2 | } |
|
1060 | | |
1061 | | template <typename Derived> |
1062 | 4 | Status ScanLocalState<Derived>::_init_profile() { |
1063 | | // 1. counters for scan node |
1064 | 4 | _rows_read_counter = ADD_COUNTER(custom_profile(), profile::ROWS_READ, TUnit::UNIT); |
1065 | 4 | _num_scanners = ADD_COUNTER(custom_profile(), profile::NUM_SCANNERS, TUnit::UNIT); |
1066 | | //custom_profile()->AddHighWaterMarkCounter("PeakMemoryUsage", TUnit::BYTES); |
1067 | | |
1068 | | // 2. counters for scanners |
1069 | 4 | _scanner_profile.reset(new RuntimeProfile(profile::SCANNER)); |
1070 | 4 | custom_profile()->add_child(_scanner_profile.get(), true, nullptr); |
1071 | | |
1072 | 4 | _newly_create_free_blocks_num = |
1073 | 4 | ADD_COUNTER(_scanner_profile, profile::NEWLY_CREATE_FREE_BLOCKS_NUM, TUnit::UNIT); |
1074 | 4 | _scan_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_GET_BLOCK_TIME); |
1075 | 4 | _scan_cpu_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_CPU_TIME); |
1076 | 4 | _filter_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_FILTER_TIME); |
1077 | | |
1078 | | // time of scan thread to wait for worker thread of the thread pool |
1079 | 4 | _scanner_wait_worker_timer = ADD_TIMER(custom_profile(), profile::SCANNER_WORKER_WAIT_TIME); |
1080 | | |
1081 | 4 | _max_scan_concurrency = |
1082 | 4 | ADD_COUNTER(custom_profile(), profile::MAX_SCAN_CONCURRENCY, TUnit::UNIT); |
1083 | 4 | _min_scan_concurrency = |
1084 | 4 | ADD_COUNTER(custom_profile(), profile::MIN_SCAN_CONCURRENCY, TUnit::UNIT); |
1085 | | |
1086 | 4 | _peak_running_scanner = |
1087 | 4 | _scanner_profile->AddHighWaterMarkCounter(profile::RUNNING_SCANNER, TUnit::UNIT); |
1088 | | |
1089 | 4 | _condition_cache_hit_counter = ADD_COUNTER(_scanner_profile, "ConditionCacheHit", TUnit::UNIT); |
1090 | 4 | _condition_cache_filtered_rows_counter = |
1091 | 4 | ADD_COUNTER(_scanner_profile, "ConditionCacheFilteredRows", TUnit::UNIT); |
1092 | | |
1093 | 4 | _partitions_pruned_by_rf_counter = |
1094 | 4 | ADD_COUNTER(custom_profile(), "PartitionsPrunedByRuntimeFilter", TUnit::UNIT); |
1095 | 4 | _total_partitions_rf_counter = |
1096 | 4 | ADD_COUNTER(custom_profile(), "TotalPartitionsForRFPruning", TUnit::UNIT); |
1097 | | |
1098 | | // Rows read from storage. |
1099 | | // Include the rows read from doris page cache. |
1100 | 4 | _scan_rows = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_ROWS, TUnit::UNIT, 1); |
1101 | | // Size of data that read from storage. |
1102 | | // Does not include rows that are cached by doris page cache. |
1103 | 4 | _scan_bytes = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_BYTES, TUnit::BYTES, 1); |
1104 | 4 | return Status::OK(); |
1105 | 4 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE13_init_profileEv _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE13_init_profileEv Line | Count | Source | 1062 | 3 | Status ScanLocalState<Derived>::_init_profile() { | 1063 | | // 1. counters for scan node | 1064 | 3 | _rows_read_counter = ADD_COUNTER(custom_profile(), profile::ROWS_READ, TUnit::UNIT); | 1065 | 3 | _num_scanners = ADD_COUNTER(custom_profile(), profile::NUM_SCANNERS, TUnit::UNIT); | 1066 | | //custom_profile()->AddHighWaterMarkCounter("PeakMemoryUsage", TUnit::BYTES); | 1067 | | | 1068 | | // 2. counters for scanners | 1069 | 3 | _scanner_profile.reset(new RuntimeProfile(profile::SCANNER)); | 1070 | 3 | custom_profile()->add_child(_scanner_profile.get(), true, nullptr); | 1071 | | | 1072 | 3 | _newly_create_free_blocks_num = | 1073 | 3 | ADD_COUNTER(_scanner_profile, profile::NEWLY_CREATE_FREE_BLOCKS_NUM, TUnit::UNIT); | 1074 | 3 | _scan_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_GET_BLOCK_TIME); | 1075 | 3 | _scan_cpu_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_CPU_TIME); | 1076 | 3 | _filter_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_FILTER_TIME); | 1077 | | | 1078 | | // time of scan thread to wait for worker thread of the thread pool | 1079 | 3 | _scanner_wait_worker_timer = ADD_TIMER(custom_profile(), profile::SCANNER_WORKER_WAIT_TIME); | 1080 | | | 1081 | 3 | _max_scan_concurrency = | 1082 | 3 | ADD_COUNTER(custom_profile(), profile::MAX_SCAN_CONCURRENCY, TUnit::UNIT); | 1083 | 3 | _min_scan_concurrency = | 1084 | 3 | ADD_COUNTER(custom_profile(), profile::MIN_SCAN_CONCURRENCY, TUnit::UNIT); | 1085 | | | 1086 | 3 | _peak_running_scanner = | 1087 | 3 | _scanner_profile->AddHighWaterMarkCounter(profile::RUNNING_SCANNER, TUnit::UNIT); | 1088 | | | 1089 | 3 | _condition_cache_hit_counter = ADD_COUNTER(_scanner_profile, "ConditionCacheHit", TUnit::UNIT); | 1090 | 3 | _condition_cache_filtered_rows_counter = | 1091 | 3 | ADD_COUNTER(_scanner_profile, "ConditionCacheFilteredRows", TUnit::UNIT); | 1092 | | | 1093 | 3 | _partitions_pruned_by_rf_counter = | 1094 | 3 | ADD_COUNTER(custom_profile(), "PartitionsPrunedByRuntimeFilter", TUnit::UNIT); | 1095 | 3 | _total_partitions_rf_counter = | 1096 | 3 | ADD_COUNTER(custom_profile(), "TotalPartitionsForRFPruning", TUnit::UNIT); | 1097 | | | 1098 | | // Rows read from storage. | 1099 | | // Include the rows read from doris page cache. | 1100 | 3 | _scan_rows = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_ROWS, TUnit::UNIT, 1); | 1101 | | // Size of data that read from storage. | 1102 | | // Does not include rows that are cached by doris page cache. | 1103 | 3 | _scan_bytes = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_BYTES, TUnit::BYTES, 1); | 1104 | 3 | return Status::OK(); | 1105 | 3 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE13_init_profileEv _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE13_init_profileEv Line | Count | Source | 1062 | 1 | Status ScanLocalState<Derived>::_init_profile() { | 1063 | | // 1. counters for scan node | 1064 | 1 | _rows_read_counter = ADD_COUNTER(custom_profile(), profile::ROWS_READ, TUnit::UNIT); | 1065 | 1 | _num_scanners = ADD_COUNTER(custom_profile(), profile::NUM_SCANNERS, TUnit::UNIT); | 1066 | | //custom_profile()->AddHighWaterMarkCounter("PeakMemoryUsage", TUnit::BYTES); | 1067 | | | 1068 | | // 2. counters for scanners | 1069 | 1 | _scanner_profile.reset(new RuntimeProfile(profile::SCANNER)); | 1070 | 1 | custom_profile()->add_child(_scanner_profile.get(), true, nullptr); | 1071 | | | 1072 | 1 | _newly_create_free_blocks_num = | 1073 | 1 | ADD_COUNTER(_scanner_profile, profile::NEWLY_CREATE_FREE_BLOCKS_NUM, TUnit::UNIT); | 1074 | 1 | _scan_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_GET_BLOCK_TIME); | 1075 | 1 | _scan_cpu_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_CPU_TIME); | 1076 | 1 | _filter_timer = ADD_TIMER(_scanner_profile, profile::SCANNER_FILTER_TIME); | 1077 | | | 1078 | | // time of scan thread to wait for worker thread of the thread pool | 1079 | 1 | _scanner_wait_worker_timer = ADD_TIMER(custom_profile(), profile::SCANNER_WORKER_WAIT_TIME); | 1080 | | | 1081 | 1 | _max_scan_concurrency = | 1082 | 1 | ADD_COUNTER(custom_profile(), profile::MAX_SCAN_CONCURRENCY, TUnit::UNIT); | 1083 | 1 | _min_scan_concurrency = | 1084 | 1 | ADD_COUNTER(custom_profile(), profile::MIN_SCAN_CONCURRENCY, TUnit::UNIT); | 1085 | | | 1086 | 1 | _peak_running_scanner = | 1087 | 1 | _scanner_profile->AddHighWaterMarkCounter(profile::RUNNING_SCANNER, TUnit::UNIT); | 1088 | | | 1089 | 1 | _condition_cache_hit_counter = ADD_COUNTER(_scanner_profile, "ConditionCacheHit", TUnit::UNIT); | 1090 | 1 | _condition_cache_filtered_rows_counter = | 1091 | 1 | ADD_COUNTER(_scanner_profile, "ConditionCacheFilteredRows", TUnit::UNIT); | 1092 | | | 1093 | 1 | _partitions_pruned_by_rf_counter = | 1094 | 1 | ADD_COUNTER(custom_profile(), "PartitionsPrunedByRuntimeFilter", TUnit::UNIT); | 1095 | 1 | _total_partitions_rf_counter = | 1096 | 1 | ADD_COUNTER(custom_profile(), "TotalPartitionsForRFPruning", TUnit::UNIT); | 1097 | | | 1098 | | // Rows read from storage. | 1099 | | // Include the rows read from doris page cache. | 1100 | 1 | _scan_rows = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_ROWS, TUnit::UNIT, 1); | 1101 | | // Size of data that read from storage. | 1102 | | // Does not include rows that are cached by doris page cache. | 1103 | 1 | _scan_bytes = ADD_COUNTER_WITH_LEVEL(custom_profile(), profile::SCAN_BYTES, TUnit::BYTES, 1); | 1104 | 1 | return Status::OK(); | 1105 | 1 | } |
|
1106 | | |
1107 | | template <typename Derived> |
1108 | 0 | Status ScanLocalState<Derived>::_get_topn_filters(RuntimeState* state) { |
1109 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1110 | 0 | std::stringstream result; |
1111 | 0 | std::copy(p._topn_filter_source_node_ids.begin(), p._topn_filter_source_node_ids.end(), |
1112 | 0 | std::ostream_iterator<int>(result, ",")); |
1113 | 0 | custom_profile()->add_info_string("TopNFilterSourceNodeIds", result.str()); |
1114 | |
|
1115 | 0 | for (auto id : get_topn_filter_source_node_ids(state, false)) { |
1116 | 0 | const auto& pred = state->get_query_ctx()->get_runtime_predicate(id); |
1117 | 0 | VExprSPtr topn_pred; |
1118 | 0 | RETURN_IF_ERROR(VTopNPred::create_vtopn_pred(pred.get_texpr(p.node_id()), id, topn_pred)); |
1119 | | |
1120 | 0 | VExprContextSPtr conjunct = VExprContext::create_shared(topn_pred); |
1121 | 0 | RETURN_IF_ERROR(conjunct->prepare( |
1122 | 0 | state, _parent->cast<typename Derived::Parent>().row_descriptor())); |
1123 | 0 | RETURN_IF_ERROR(conjunct->open(state)); |
1124 | 0 | _conjuncts.emplace_back(conjunct); |
1125 | 0 | } |
1126 | 0 | for (auto id : get_topn_filter_source_node_ids(state, true)) { |
1127 | 0 | const auto& pred = state->get_query_ctx()->get_runtime_predicate(id); |
1128 | 0 | VExprSPtr topn_pred; |
1129 | 0 | RETURN_IF_ERROR(VTopNPred::create_vtopn_pred(pred.get_texpr(p.node_id()), id, topn_pred)); |
1130 | | |
1131 | 0 | VExprContextSPtr conjunct = VExprContext::create_shared(topn_pred); |
1132 | 0 | RETURN_IF_ERROR(conjunct->prepare( |
1133 | 0 | state, _parent->cast<typename Derived::Parent>().row_descriptor())); |
1134 | 0 | RETURN_IF_ERROR(conjunct->open(state)); |
1135 | 0 | _conjuncts.emplace_back(conjunct); |
1136 | 0 | } |
1137 | 0 | return Status::OK(); |
1138 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE17_get_topn_filtersEPNS_12RuntimeStateE |
1139 | | |
1140 | | template <typename Derived> |
1141 | | void ScanLocalState<Derived>::_filter_and_collect_cast_type_for_variant( |
1142 | | const VExpr* expr, |
1143 | 0 | std::unordered_map<std::string, std::vector<DataTypePtr>>& colname_to_cast_types) { |
1144 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1145 | 0 | const auto* cast_expr = dynamic_cast<const VCastExpr*>(expr); |
1146 | 0 | if (cast_expr != nullptr) { |
1147 | 0 | const auto* src_slot = |
1148 | 0 | cast_expr->get_child(0)->node_type() == TExprNodeType::SLOT_REF |
1149 | 0 | ? dynamic_cast<const VSlotRef*>(cast_expr->get_child(0).get()) |
1150 | 0 | : nullptr; |
1151 | 0 | if (src_slot == nullptr) { |
1152 | 0 | return; |
1153 | 0 | } |
1154 | 0 | std::vector<SlotDescriptor*> slots = output_tuple_desc()->slots(); |
1155 | 0 | SlotDescriptor* src_slot_desc = p._slot_id_to_slot_desc[src_slot->slot_id()]; |
1156 | 0 | auto type_desc = cast_expr->get_target_type(); |
1157 | 0 | if (src_slot_desc->type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { |
1158 | 0 | colname_to_cast_types[src_slot_desc->col_name()].push_back(type_desc); |
1159 | 0 | } |
1160 | 0 | } |
1161 | 0 | for (const auto& child : expr->children()) { |
1162 | 0 | _filter_and_collect_cast_type_for_variant(child.get(), colname_to_cast_types); |
1163 | 0 | } |
1164 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE41_filter_and_collect_cast_type_for_variantEPKNS_5VExprERSt13unordered_mapINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISH_EESt4hashISC_ESt8equal_toISC_ESaISt4pairIKSC_SJ_EEE |
1165 | | |
1166 | | template <typename Derived> |
1167 | 0 | void ScanLocalState<Derived>::get_cast_types_for_variants() { |
1168 | 0 | std::unordered_map<std::string, std::vector<DataTypePtr>> colname_to_cast_types; |
1169 | 0 | for (auto it = _conjuncts.begin(); it != _conjuncts.end();) { |
1170 | 0 | auto& conjunct = *it; |
1171 | 0 | if (conjunct->root()) { |
1172 | 0 | _filter_and_collect_cast_type_for_variant(conjunct->root().get(), |
1173 | 0 | colname_to_cast_types); |
1174 | 0 | } |
1175 | 0 | ++it; |
1176 | 0 | } |
1177 | | // cast to one certain type for variant could utilize fully predicates performance |
1178 | | // when storage layer type equals to cast type |
1179 | 0 | for (const auto& [slotid, types] : colname_to_cast_types) { |
1180 | 0 | if (types.size() == 1) { |
1181 | 0 | _cast_types_for_variants[slotid] = types[0]; |
1182 | 0 | } |
1183 | 0 | } |
1184 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE27get_cast_types_for_variantsEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE27get_cast_types_for_variantsEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE27get_cast_types_for_variantsEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE27get_cast_types_for_variantsEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE27get_cast_types_for_variantsEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE27get_cast_types_for_variantsEv |
1185 | | |
1186 | | template <typename LocalStateType> |
1187 | | ScanOperatorX<LocalStateType>::ScanOperatorX(ObjectPool* pool, const TPlanNode& tnode, |
1188 | | int operator_id, const DescriptorTbl& descs, |
1189 | | int parallel_tasks) |
1190 | 20 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), |
1191 | 20 | _runtime_filter_descs(tnode.runtime_filters), |
1192 | 20 | _parallel_tasks(parallel_tasks) { |
1193 | 20 | if (tnode.__isset.push_down_count) { |
1194 | 0 | _push_down_count = tnode.push_down_count; |
1195 | 0 | } |
1196 | 20 | _shared_scan_limit.store(this->_limit, std::memory_order_relaxed); |
1197 | 20 | } _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Line | Count | Source | 1190 | 17 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), | 1191 | 17 | _runtime_filter_descs(tnode.runtime_filters), | 1192 | 17 | _parallel_tasks(parallel_tasks) { | 1193 | 17 | if (tnode.__isset.push_down_count) { | 1194 | 0 | _push_down_count = tnode.push_down_count; | 1195 | 0 | } | 1196 | 17 | _shared_scan_limit.store(this->_limit, std::memory_order_relaxed); | 1197 | 17 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Line | Count | Source | 1190 | 3 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), | 1191 | 3 | _runtime_filter_descs(tnode.runtime_filters), | 1192 | 3 | _parallel_tasks(parallel_tasks) { | 1193 | 3 | if (tnode.__isset.push_down_count) { | 1194 | 0 | _push_down_count = tnode.push_down_count; | 1195 | 0 | } | 1196 | 3 | _shared_scan_limit.store(this->_limit, std::memory_order_relaxed); | 1197 | 3 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi |
1198 | | |
1199 | | template <typename LocalStateType> |
1200 | 7 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { |
1201 | 7 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); |
1202 | | |
1203 | 7 | const TQueryOptions& query_options = state->query_options(); |
1204 | 7 | if (query_options.__isset.max_scan_key_num) { |
1205 | 0 | _max_scan_key_num = query_options.max_scan_key_num; |
1206 | 0 | } |
1207 | 7 | if (query_options.__isset.max_pushdown_conditions_per_column) { |
1208 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; |
1209 | 0 | } |
1210 | 7 | #ifdef BE_TEST |
1211 | 7 | _mem_arb = nullptr; |
1212 | | #else |
1213 | | _mem_arb = state->get_query_ctx()->mem_arb(); |
1214 | | #endif |
1215 | 7 | if (_mem_arb) { |
1216 | 0 | _mem_arb->register_scan_node(); |
1217 | 0 | _mem_limiter = |
1218 | 0 | MemLimiter::create_shared(state->query_id(), state->query_parallel_instance_num(), |
1219 | 0 | OperatorX<LocalStateType>::is_serial_operator(), |
1220 | 0 | state->get_query_ctx()->get_query_options().mem_limit); |
1221 | 0 | } |
1222 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated |
1223 | | // Introduced a new field : tnode.push_down_agg_type_opt |
1224 | | // |
1225 | | // make it compatible here |
1226 | 7 | if (tnode.__isset.push_down_agg_type_opt) { |
1227 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; |
1228 | 7 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { |
1229 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; |
1230 | 7 | } else { |
1231 | 7 | _push_down_agg_type = TPushAggOp::type::NONE; |
1232 | 7 | } |
1233 | | |
1234 | 7 | if (tnode.__isset.topn_filter_source_node_ids) { |
1235 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; |
1236 | 0 | } |
1237 | | |
1238 | | // Which means the request could be fullfilled in a single segment iterator request. |
1239 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, |
1240 | | // now add some check for unique_table let running only one instance for select limit n. |
1241 | 7 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { |
1242 | 6 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); |
1243 | 6 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || |
1244 | 6 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && |
1245 | 5 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { |
1246 | 5 | if (tnode.limit > 0 && |
1247 | 5 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { |
1248 | 1 | _should_run_serial = true; |
1249 | 1 | } |
1250 | 5 | } |
1251 | 6 | } |
1252 | | |
1253 | 7 | return Status::OK(); |
1254 | 7 | } _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Line | Count | Source | 1200 | 4 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { | 1201 | 4 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); | 1202 | | | 1203 | 4 | const TQueryOptions& query_options = state->query_options(); | 1204 | 4 | if (query_options.__isset.max_scan_key_num) { | 1205 | 0 | _max_scan_key_num = query_options.max_scan_key_num; | 1206 | 0 | } | 1207 | 4 | if (query_options.__isset.max_pushdown_conditions_per_column) { | 1208 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; | 1209 | 0 | } | 1210 | 4 | #ifdef BE_TEST | 1211 | 4 | _mem_arb = nullptr; | 1212 | | #else | 1213 | | _mem_arb = state->get_query_ctx()->mem_arb(); | 1214 | | #endif | 1215 | 4 | if (_mem_arb) { | 1216 | 0 | _mem_arb->register_scan_node(); | 1217 | 0 | _mem_limiter = | 1218 | 0 | MemLimiter::create_shared(state->query_id(), state->query_parallel_instance_num(), | 1219 | 0 | OperatorX<LocalStateType>::is_serial_operator(), | 1220 | 0 | state->get_query_ctx()->get_query_options().mem_limit); | 1221 | 0 | } | 1222 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated | 1223 | | // Introduced a new field : tnode.push_down_agg_type_opt | 1224 | | // | 1225 | | // make it compatible here | 1226 | 4 | if (tnode.__isset.push_down_agg_type_opt) { | 1227 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; | 1228 | 4 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { | 1229 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; | 1230 | 4 | } else { | 1231 | 4 | _push_down_agg_type = TPushAggOp::type::NONE; | 1232 | 4 | } | 1233 | | | 1234 | 4 | if (tnode.__isset.topn_filter_source_node_ids) { | 1235 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; | 1236 | 0 | } | 1237 | | | 1238 | | // Which means the request could be fullfilled in a single segment iterator request. | 1239 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, | 1240 | | // now add some check for unique_table let running only one instance for select limit n. | 1241 | 4 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { | 1242 | 3 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); | 1243 | 3 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || | 1244 | 3 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && | 1245 | 2 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { | 1246 | 2 | if (tnode.limit > 0 && | 1247 | 2 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { | 1248 | 1 | _should_run_serial = true; | 1249 | 1 | } | 1250 | 2 | } | 1251 | 3 | } | 1252 | | | 1253 | 4 | return Status::OK(); | 1254 | 4 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Line | Count | Source | 1200 | 3 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { | 1201 | 3 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); | 1202 | | | 1203 | 3 | const TQueryOptions& query_options = state->query_options(); | 1204 | 3 | if (query_options.__isset.max_scan_key_num) { | 1205 | 0 | _max_scan_key_num = query_options.max_scan_key_num; | 1206 | 0 | } | 1207 | 3 | if (query_options.__isset.max_pushdown_conditions_per_column) { | 1208 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; | 1209 | 0 | } | 1210 | 3 | #ifdef BE_TEST | 1211 | 3 | _mem_arb = nullptr; | 1212 | | #else | 1213 | | _mem_arb = state->get_query_ctx()->mem_arb(); | 1214 | | #endif | 1215 | 3 | if (_mem_arb) { | 1216 | 0 | _mem_arb->register_scan_node(); | 1217 | 0 | _mem_limiter = | 1218 | 0 | MemLimiter::create_shared(state->query_id(), state->query_parallel_instance_num(), | 1219 | 0 | OperatorX<LocalStateType>::is_serial_operator(), | 1220 | 0 | state->get_query_ctx()->get_query_options().mem_limit); | 1221 | 0 | } | 1222 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated | 1223 | | // Introduced a new field : tnode.push_down_agg_type_opt | 1224 | | // | 1225 | | // make it compatible here | 1226 | 3 | if (tnode.__isset.push_down_agg_type_opt) { | 1227 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; | 1228 | 3 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { | 1229 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; | 1230 | 3 | } else { | 1231 | 3 | _push_down_agg_type = TPushAggOp::type::NONE; | 1232 | 3 | } | 1233 | | | 1234 | 3 | if (tnode.__isset.topn_filter_source_node_ids) { | 1235 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; | 1236 | 0 | } | 1237 | | | 1238 | | // Which means the request could be fullfilled in a single segment iterator request. | 1239 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, | 1240 | | // now add some check for unique_table let running only one instance for select limit n. | 1241 | 3 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { | 1242 | 3 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); | 1243 | 3 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || | 1244 | 3 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && | 1245 | 3 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { | 1246 | 3 | if (tnode.limit > 0 && | 1247 | 3 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { | 1248 | 0 | _should_run_serial = true; | 1249 | 0 | } | 1250 | 3 | } | 1251 | 3 | } | 1252 | | | 1253 | 3 | return Status::OK(); | 1254 | 3 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE |
1255 | | |
1256 | | template <typename LocalStateType> |
1257 | 3 | Status ScanOperatorX<LocalStateType>::prepare(RuntimeState* state) { |
1258 | 3 | _input_tuple_desc = state->desc_tbl().get_tuple_descriptor(_input_tuple_id); |
1259 | 3 | _output_tuple_desc = state->desc_tbl().get_tuple_descriptor(_output_tuple_id); |
1260 | 3 | RETURN_IF_ERROR(OperatorX<LocalStateType>::prepare(state)); |
1261 | | |
1262 | 3 | const auto slots = _output_tuple_desc->slots(); |
1263 | 9 | for (auto* slot : slots) { |
1264 | 9 | _colname_to_slot_id[slot->col_name()] = slot->id(); |
1265 | 9 | _slot_id_to_slot_desc[slot->id()] = slot; |
1266 | 9 | } |
1267 | 3 | for (auto id : _topn_filter_source_node_ids) { |
1268 | 0 | int cid = -1; |
1269 | 0 | if (state->get_query_ctx()->get_runtime_predicate(id).target_is_slot(node_id())) { |
1270 | 0 | auto s = _slot_id_to_slot_desc[state->get_query_ctx() |
1271 | 0 | ->get_runtime_predicate(id) |
1272 | 0 | .get_texpr(node_id()) |
1273 | 0 | .nodes[0] |
1274 | 0 | .slot_ref.slot_id]; |
1275 | 0 | DCHECK(s != nullptr); |
1276 | 0 | if (can_push_down_column_predicate(s)) { |
1277 | 0 | auto col_name = s->col_name(); |
1278 | 0 | cid = get_column_id(col_name); |
1279 | 0 | } |
1280 | 0 | } |
1281 | 0 | RETURN_IF_ERROR(state->get_query_ctx()->get_runtime_predicate(id).init_target( |
1282 | 0 | node_id(), _slot_id_to_slot_desc, cid)); |
1283 | 0 | } |
1284 | | |
1285 | 3 | RETURN_IF_CANCELLED(state); |
1286 | 3 | return Status::OK(); |
1287 | 3 | } Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE7prepareEPNS_12RuntimeStateE _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE7prepareEPNS_12RuntimeStateE Line | Count | Source | 1257 | 3 | Status ScanOperatorX<LocalStateType>::prepare(RuntimeState* state) { | 1258 | 3 | _input_tuple_desc = state->desc_tbl().get_tuple_descriptor(_input_tuple_id); | 1259 | 3 | _output_tuple_desc = state->desc_tbl().get_tuple_descriptor(_output_tuple_id); | 1260 | 3 | RETURN_IF_ERROR(OperatorX<LocalStateType>::prepare(state)); | 1261 | | | 1262 | 3 | const auto slots = _output_tuple_desc->slots(); | 1263 | 9 | for (auto* slot : slots) { | 1264 | 9 | _colname_to_slot_id[slot->col_name()] = slot->id(); | 1265 | 9 | _slot_id_to_slot_desc[slot->id()] = slot; | 1266 | 9 | } | 1267 | 3 | for (auto id : _topn_filter_source_node_ids) { | 1268 | 0 | int cid = -1; | 1269 | 0 | if (state->get_query_ctx()->get_runtime_predicate(id).target_is_slot(node_id())) { | 1270 | 0 | auto s = _slot_id_to_slot_desc[state->get_query_ctx() | 1271 | 0 | ->get_runtime_predicate(id) | 1272 | 0 | .get_texpr(node_id()) | 1273 | 0 | .nodes[0] | 1274 | 0 | .slot_ref.slot_id]; | 1275 | 0 | DCHECK(s != nullptr); | 1276 | 0 | if (can_push_down_column_predicate(s)) { | 1277 | 0 | auto col_name = s->col_name(); | 1278 | 0 | cid = get_column_id(col_name); | 1279 | 0 | } | 1280 | 0 | } | 1281 | 0 | RETURN_IF_ERROR(state->get_query_ctx()->get_runtime_predicate(id).init_target( | 1282 | 0 | node_id(), _slot_id_to_slot_desc, cid)); | 1283 | 0 | } | 1284 | | | 1285 | 3 | RETURN_IF_CANCELLED(state); | 1286 | 3 | return Status::OK(); | 1287 | 3 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE7prepareEPNS_12RuntimeStateE |
1288 | | |
1289 | | template <typename Derived> |
1290 | 3 | Status ScanLocalState<Derived>::close(RuntimeState* state) { |
1291 | 3 | if (_closed) { |
1292 | 0 | return Status::OK(); |
1293 | 0 | } |
1294 | 3 | COUNTER_UPDATE(exec_time_counter(), _scan_dependency->watcher_elapse_time()); |
1295 | 3 | int64_t rf_time = 0; |
1296 | 3 | for (auto& dep : _filter_dependencies) { |
1297 | 0 | rf_time += dep->watcher_elapse_time(); |
1298 | 0 | } |
1299 | 3 | COUNTER_UPDATE(exec_time_counter(), rf_time); |
1300 | 3 | SCOPED_TIMER(_close_timer); |
1301 | | |
1302 | 3 | SCOPED_TIMER(exec_time_counter()); |
1303 | 3 | if (auto ctx = _scanner_ctx.load()) { |
1304 | 0 | ctx->stop_scanners(state); |
1305 | | // _scanner_ctx may be accessed in debug_string concurrently |
1306 | | // so use atomic shared ptr to avoid use after free |
1307 | 0 | _scanner_ctx.store(nullptr); |
1308 | 0 | } |
1309 | 3 | std::list<std::shared_ptr<ScannerDelegate>> {}.swap(_scanners); |
1310 | 3 | COUNTER_SET(_wait_for_dependency_timer, _scan_dependency->watcher_elapse_time()); |
1311 | 3 | COUNTER_SET(_wait_for_rf_timer, rf_time); |
1312 | 3 | _helper.collect_realtime_profile(custom_profile()); |
1313 | 3 | return PipelineXLocalState<>::close(state); |
1314 | 3 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE5closeEPNS_12RuntimeStateE _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE5closeEPNS_12RuntimeStateE Line | Count | Source | 1290 | 3 | Status ScanLocalState<Derived>::close(RuntimeState* state) { | 1291 | 3 | if (_closed) { | 1292 | 0 | return Status::OK(); | 1293 | 0 | } | 1294 | 3 | COUNTER_UPDATE(exec_time_counter(), _scan_dependency->watcher_elapse_time()); | 1295 | 3 | int64_t rf_time = 0; | 1296 | 3 | for (auto& dep : _filter_dependencies) { | 1297 | 0 | rf_time += dep->watcher_elapse_time(); | 1298 | 0 | } | 1299 | 3 | COUNTER_UPDATE(exec_time_counter(), rf_time); | 1300 | 3 | SCOPED_TIMER(_close_timer); | 1301 | | | 1302 | 3 | SCOPED_TIMER(exec_time_counter()); | 1303 | 3 | if (auto ctx = _scanner_ctx.load()) { | 1304 | 0 | ctx->stop_scanners(state); | 1305 | | // _scanner_ctx may be accessed in debug_string concurrently | 1306 | | // so use atomic shared ptr to avoid use after free | 1307 | 0 | _scanner_ctx.store(nullptr); | 1308 | 0 | } | 1309 | 3 | std::list<std::shared_ptr<ScannerDelegate>> {}.swap(_scanners); | 1310 | 3 | COUNTER_SET(_wait_for_dependency_timer, _scan_dependency->watcher_elapse_time()); | 1311 | 3 | COUNTER_SET(_wait_for_rf_timer, rf_time); | 1312 | 3 | _helper.collect_realtime_profile(custom_profile()); | 1313 | 3 | return PipelineXLocalState<>::close(state); | 1314 | 3 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE5closeEPNS_12RuntimeStateE |
1315 | | |
1316 | | template <typename LocalStateType> |
1317 | 0 | Status ScanOperatorX<LocalStateType>::get_block_impl(RuntimeState* state, Block* block, bool* eos) { |
1318 | 0 | auto& local_state = get_local_state(state); |
1319 | 0 | SCOPED_TIMER(local_state.exec_time_counter()); |
1320 | |
|
1321 | 0 | if (state->is_cancelled()) { |
1322 | 0 | if (auto ctx = local_state._scanner_ctx.load()) { |
1323 | 0 | ctx->stop_scanners(state); |
1324 | 0 | } |
1325 | 0 | return state->cancel_reason(); |
1326 | 0 | } |
1327 | | |
1328 | 0 | if (local_state._eos) { |
1329 | 0 | *eos = true; |
1330 | 0 | return Status::OK(); |
1331 | 0 | } |
1332 | | |
1333 | 0 | auto ctx = local_state._scanner_ctx.load(); |
1334 | |
|
1335 | 0 | DCHECK(ctx != nullptr); |
1336 | 0 | RETURN_IF_ERROR(ctx->get_block_from_queue(state, block, eos, 0)); |
1337 | | |
1338 | 0 | local_state.reached_limit(block, eos); |
1339 | 0 | if (*eos) { |
1340 | | // reach limit, stop the scanners. |
1341 | 0 | ctx->stop_scanners(state); |
1342 | 0 | local_state._scanner_profile->add_info_string("EOS", "True"); |
1343 | 0 | } |
1344 | |
|
1345 | 0 | return Status::OK(); |
1346 | 0 | } Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE14get_block_implEPNS_12RuntimeStateEPNS_5BlockEPb |
1347 | | |
1348 | | template <typename LocalStateType> |
1349 | 0 | size_t ScanOperatorX<LocalStateType>::get_reserve_mem_size(RuntimeState* state) { |
1350 | 0 | auto& local_state = get_local_state(state); |
1351 | 0 | auto ctx = local_state._scanner_ctx.load(); |
1352 | 0 | if (!local_state._opened || local_state._closed || !ctx) { |
1353 | 0 | return config::doris_scanner_row_bytes; |
1354 | 0 | } |
1355 | | |
1356 | 0 | if (local_state.low_memory_mode()) { |
1357 | 0 | return ctx->low_memory_mode_scan_bytes_per_scanner() * ctx->low_memory_mode_scanners(); |
1358 | 0 | } else { |
1359 | 0 | const auto peak_usage = local_state._memory_used_counter->value(); |
1360 | 0 | const auto block_usage = ctx->block_memory_usage(); |
1361 | 0 | if (peak_usage > 0) { |
1362 | | // It is only a safty check, to avoid some counter not right. |
1363 | 0 | if (peak_usage > block_usage) { |
1364 | 0 | return peak_usage - block_usage; |
1365 | 0 | } else { |
1366 | 0 | return config::doris_scanner_row_bytes; |
1367 | 0 | } |
1368 | 0 | } else { |
1369 | | // If the scan operator is first time to run, then we think it will occupy doris_scanner_row_bytes. |
1370 | | // It maybe a little smaller than actual usage. |
1371 | 0 | return config::doris_scanner_row_bytes; |
1372 | | // return local_state._scanner_ctx->max_bytes_in_queue(); |
1373 | 0 | } |
1374 | 0 | } |
1375 | 0 | } Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE20get_reserve_mem_sizeEPNS_12RuntimeStateE |
1376 | | |
1377 | | template class ScanOperatorX<OlapScanLocalState>; |
1378 | | template class ScanLocalState<OlapScanLocalState>; |
1379 | | template class ScanOperatorX<JDBCScanLocalState>; |
1380 | | template class ScanLocalState<JDBCScanLocalState>; |
1381 | | template class ScanOperatorX<FileScanLocalState>; |
1382 | | template class ScanLocalState<FileScanLocalState>; |
1383 | | template class ScanLocalState<MetaScanLocalState>; |
1384 | | template class ScanOperatorX<MetaScanLocalState>; |
1385 | | template class ScanOperatorX<GroupCommitLocalState>; |
1386 | | template class ScanLocalState<GroupCommitLocalState>; |
1387 | | |
1388 | | #ifdef BE_TEST |
1389 | | template class ScanOperatorX<MockScanLocalState>; |
1390 | | template class ScanLocalState<MockScanLocalState>; |
1391 | | #endif |
1392 | | |
1393 | | } // namespace doris |