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/es_scan_operator.h" |
31 | | #include "exec/operator/file_scan_operator.h" |
32 | | #include "exec/operator/group_commit_scan_operator.h" |
33 | | #include "exec/operator/jdbc_scan_operator.h" |
34 | | #include "exec/operator/meta_scan_operator.h" |
35 | | #include "exec/operator/mock_scan_operator.h" |
36 | | #include "exec/operator/olap_scan_operator.h" |
37 | | #include "exec/operator/operator.h" |
38 | | #include "exec/runtime_filter/runtime_filter_consumer_helper.h" |
39 | | #include "exec/scan/scanner_context.h" |
40 | | #include "exprs/function/in.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/vruntimefilter_wrapper.h" |
49 | | #include "exprs/vslot_ref.h" |
50 | | #include "exprs/vtopn_pred.h" |
51 | | #include "runtime/descriptors.h" |
52 | | #include "runtime/runtime_profile.h" |
53 | | #include "storage/predicate/null_predicate.h" |
54 | | #include "storage/predicate/predicate_creator.h" |
55 | | |
56 | | namespace doris { |
57 | | |
58 | | #include "common/compile_check_begin.h" |
59 | | |
60 | | #define RETURN_IF_PUSH_DOWN(stmt, status) \ |
61 | 99 | if (pdt == PushDownType::UNACCEPTABLE) { \ |
62 | 99 | status = stmt; \ |
63 | 99 | if (!status.ok()) { \ |
64 | 0 | return; \ |
65 | 0 | } \ |
66 | 99 | } else { \ |
67 | 0 | return; \ |
68 | 0 | } |
69 | | |
70 | | template <typename Derived> |
71 | 16 | bool ScanLocalState<Derived>::should_run_serial() const { |
72 | 16 | return _parent->cast<typename Derived::Parent>()._should_run_serial; |
73 | 16 | } _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE17should_run_serialEv Line | Count | Source | 71 | 14 | bool ScanLocalState<Derived>::should_run_serial() const { | 72 | 14 | return _parent->cast<typename Derived::Parent>()._should_run_serial; | 73 | 14 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17should_run_serialEv _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE17should_run_serialEv Line | Count | Source | 71 | 2 | bool ScanLocalState<Derived>::should_run_serial() const { | 72 | 2 | return _parent->cast<typename Derived::Parent>()._should_run_serial; | 73 | 2 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_16EsScanLocalStateEE17should_run_serialEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE17should_run_serialEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17should_run_serialEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE17should_run_serialEv |
74 | | |
75 | | Status ScanLocalStateBase::update_late_arrival_runtime_filter(RuntimeState* state, |
76 | 0 | int& arrived_rf_num) { |
77 | | // Lock needed because _conjuncts can be accessed concurrently by multiple scanner threads |
78 | 0 | std::unique_lock lock(_conjuncts_lock); |
79 | 0 | RETURN_IF_ERROR(_helper.try_append_late_arrival_runtime_filter(state, _parent->row_descriptor(), |
80 | 0 | arrived_rf_num, _conjuncts)); |
81 | 0 | if (state->enable_adjust_conjunct_order_by_cost()) { |
82 | 0 | std::ranges::sort(_conjuncts, [](const auto& a, const auto& b) { |
83 | 0 | return a->execute_cost() < b->execute_cost(); |
84 | 0 | }); |
85 | 0 | }; |
86 | 0 | return Status::OK(); |
87 | 0 | } |
88 | | |
89 | 0 | Status ScanLocalStateBase::clone_conjunct_ctxs(VExprContextSPtrs& scanner_conjuncts) { |
90 | | // Lock needed because _conjuncts can be accessed concurrently by multiple scanner threads |
91 | 0 | std::unique_lock lock(_conjuncts_lock); |
92 | 0 | scanner_conjuncts.resize(_conjuncts.size()); |
93 | 0 | for (size_t i = 0; i != _conjuncts.size(); ++i) { |
94 | 0 | RETURN_IF_ERROR(_conjuncts[i]->clone(_state, scanner_conjuncts[i])); |
95 | 0 | } |
96 | 0 | return Status::OK(); |
97 | 0 | } |
98 | | |
99 | 0 | int ScanLocalStateBase::max_scanners_concurrency(RuntimeState* state) const { |
100 | | // For select * from table limit 10; should just use one thread. |
101 | 0 | if (should_run_serial()) { |
102 | 0 | return 1; |
103 | 0 | } |
104 | | /* |
105 | | * The max concurrency of scanners for each ScanLocalStateBase is determined by: |
106 | | * 1. User specified max_scanners_concurrency which is set through session variable. |
107 | | * 2. Default: 4 |
108 | | * |
109 | | * If this is a serial operator, the max concurrency should multiply by the number of parallel instances of the operator. |
110 | | */ |
111 | 0 | return (state->max_scanners_concurrency() > 0 ? state->max_scanners_concurrency() : 4) * |
112 | 0 | (state->query_parallel_instance_num() / _parent->parallelism(state)); |
113 | 0 | } |
114 | | |
115 | 14 | int ScanLocalStateBase::min_scanners_concurrency(RuntimeState* state) const { |
116 | 14 | if (should_run_serial()) { |
117 | 0 | return 1; |
118 | 0 | } |
119 | | /* |
120 | | * The min concurrency of scanners for each ScanLocalStateBase is determined by: |
121 | | * 1. User specified min_scanners_concurrency which is set through session variable. |
122 | | * 2. Default: 1 |
123 | | * |
124 | | * If this is a serial operator, the max concurrency should multiply by the number of parallel instances of the operator. |
125 | | */ |
126 | 14 | return (state->min_scanners_concurrency() > 0 ? state->min_scanners_concurrency() : 1) * |
127 | 14 | (state->query_parallel_instance_num() / _parent->parallelism(state)); |
128 | 14 | } |
129 | | |
130 | 0 | ScannerScheduler* ScanLocalStateBase::scan_scheduler(RuntimeState* state) const { |
131 | 0 | return state->get_query_ctx()->get_scan_scheduler(); |
132 | 0 | } |
133 | | |
134 | | template <typename Derived> |
135 | 2 | Status ScanLocalState<Derived>::init(RuntimeState* state, LocalStateInfo& info) { |
136 | 2 | RETURN_IF_ERROR(PipelineXLocalState<>::init(state, info)); |
137 | 2 | _scan_dependency = Dependency::create_shared(_parent->operator_id(), _parent->node_id(), |
138 | 2 | _parent->get_name() + "_DEPENDENCY"); |
139 | 2 | _wait_for_dependency_timer = ADD_TIMER_WITH_LEVEL( |
140 | 2 | common_profile(), "WaitForDependency[" + _scan_dependency->name() + "]Time", 1); |
141 | 2 | SCOPED_TIMER(exec_time_counter()); |
142 | 2 | SCOPED_TIMER(_init_timer); |
143 | 2 | auto& p = _parent->cast<typename Derived::Parent>(); |
144 | 2 | _max_pushdown_conditions_per_column = p._max_pushdown_conditions_per_column; |
145 | 2 | RETURN_IF_ERROR(_helper.init(state, p.is_serial_operator(), p.node_id(), p.operator_id(), |
146 | 2 | _filter_dependencies, p.get_name() + "_FILTER_DEPENDENCY")); |
147 | 2 | RETURN_IF_ERROR(_init_profile()); |
148 | 2 | set_scan_ranges(state, info.scan_ranges); |
149 | | |
150 | 2 | _wait_for_rf_timer = ADD_TIMER(common_profile(), "WaitForRuntimeFilter"); |
151 | 2 | return Status::OK(); |
152 | 2 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Line | Count | Source | 135 | 2 | Status ScanLocalState<Derived>::init(RuntimeState* state, LocalStateInfo& info) { | 136 | 2 | RETURN_IF_ERROR(PipelineXLocalState<>::init(state, info)); | 137 | 2 | _scan_dependency = Dependency::create_shared(_parent->operator_id(), _parent->node_id(), | 138 | 2 | _parent->get_name() + "_DEPENDENCY"); | 139 | 2 | _wait_for_dependency_timer = ADD_TIMER_WITH_LEVEL( | 140 | 2 | common_profile(), "WaitForDependency[" + _scan_dependency->name() + "]Time", 1); | 141 | 2 | SCOPED_TIMER(exec_time_counter()); | 142 | 2 | SCOPED_TIMER(_init_timer); | 143 | 2 | auto& p = _parent->cast<typename Derived::Parent>(); | 144 | 2 | _max_pushdown_conditions_per_column = p._max_pushdown_conditions_per_column; | 145 | 2 | RETURN_IF_ERROR(_helper.init(state, p.is_serial_operator(), p.node_id(), p.operator_id(), | 146 | 2 | _filter_dependencies, p.get_name() + "_FILTER_DEPENDENCY")); | 147 | 2 | RETURN_IF_ERROR(_init_profile()); | 148 | 2 | set_scan_ranges(state, info.scan_ranges); | 149 | | | 150 | 2 | _wait_for_rf_timer = ADD_TIMER(common_profile(), "WaitForRuntimeFilter"); | 151 | 2 | return Status::OK(); | 152 | 2 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE4initEPNS_12RuntimeStateERNS_14LocalStateInfoE |
153 | | |
154 | | template <typename Derived> |
155 | 0 | Status ScanLocalState<Derived>::open(RuntimeState* state) { |
156 | 0 | SCOPED_TIMER(exec_time_counter()); |
157 | 0 | SCOPED_TIMER(_open_timer); |
158 | 0 | if (_opened) { |
159 | 0 | return Status::OK(); |
160 | 0 | } |
161 | 0 | RETURN_IF_ERROR(PipelineXLocalState<>::open(state)); |
162 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
163 | | |
164 | | // init id_file_map() for runtime state |
165 | 0 | std::vector<SlotDescriptor*> slots = p._output_tuple_desc->slots(); |
166 | 0 | for (auto slot : slots) { |
167 | 0 | if (slot->col_name().starts_with(BeConsts::GLOBAL_ROWID_COL)) { |
168 | 0 | state->set_id_file_map(); |
169 | 0 | } |
170 | 0 | } |
171 | |
|
172 | 0 | _common_expr_ctxs_push_down.resize(p._common_expr_ctxs_push_down.size()); |
173 | 0 | for (size_t i = 0; i < _common_expr_ctxs_push_down.size(); i++) { |
174 | 0 | RETURN_IF_ERROR( |
175 | 0 | p._common_expr_ctxs_push_down[i]->clone(state, _common_expr_ctxs_push_down[i])); |
176 | 0 | } |
177 | 0 | RETURN_IF_ERROR(_helper.acquire_runtime_filter(state, _conjuncts, p.row_descriptor())); |
178 | | |
179 | | // Disable condition cache in topn filter valid. TODO:: Try to support the topn filter in condition cache |
180 | 0 | if (state->query_options().condition_cache_digest && p._topn_filter_source_node_ids.empty()) { |
181 | 0 | _condition_cache_digest = state->query_options().condition_cache_digest; |
182 | 0 | for (auto& conjunct : _conjuncts) { |
183 | 0 | _condition_cache_digest = conjunct->get_digest(_condition_cache_digest); |
184 | 0 | if (!_condition_cache_digest) { |
185 | 0 | break; |
186 | 0 | } |
187 | 0 | } |
188 | 0 | } else { |
189 | 0 | _condition_cache_digest = 0; |
190 | 0 | } |
191 | |
|
192 | 0 | RETURN_IF_ERROR(_process_conjuncts(state)); |
193 | | |
194 | 0 | auto status = _eos ? Status::OK() : _prepare_scanners(); |
195 | 0 | RETURN_IF_ERROR(status); |
196 | 0 | if (auto ctx = _scanner_ctx.load()) { |
197 | 0 | DCHECK(!_eos && _num_scanners->value() > 0); |
198 | 0 | RETURN_IF_ERROR(ctx->init()); |
199 | 0 | } |
200 | 0 | _opened = true; |
201 | 0 | return status; |
202 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE4openEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE4openEPNS_12RuntimeStateE |
203 | | |
204 | | static std::string predicates_to_string( |
205 | | const phmap::flat_hash_map<int, std::vector<std::shared_ptr<ColumnPredicate>>>& |
206 | 0 | slot_id_to_predicates) { |
207 | 0 | fmt::memory_buffer debug_string_buffer; |
208 | 0 | for (const auto& [slot_id, predicates] : slot_id_to_predicates) { |
209 | 0 | if (predicates.empty()) { |
210 | 0 | continue; |
211 | 0 | } |
212 | 0 | fmt::format_to(debug_string_buffer, "Slot ID: {}: [", slot_id); |
213 | 0 | for (const auto& predicate : predicates) { |
214 | 0 | fmt::format_to(debug_string_buffer, "{{{}}}, ", predicate->debug_string()); |
215 | 0 | } |
216 | 0 | fmt::format_to(debug_string_buffer, "] "); |
217 | 0 | } |
218 | 0 | return fmt::to_string(debug_string_buffer); |
219 | 0 | } |
220 | | |
221 | | static void init_slot_value_range( |
222 | | phmap::flat_hash_map<int, ColumnValueRangeType>& slot_id_to_value_range, |
223 | 0 | SlotDescriptor* slot, const DataTypePtr type_desc) { |
224 | 0 | switch (type_desc->get_primitive_type()) { |
225 | 0 | #define M(NAME) \ |
226 | 0 | case TYPE_##NAME: { \ |
227 | 0 | ColumnValueRange<TYPE_##NAME> range(slot->col_name(), slot->is_nullable(), \ |
228 | 0 | cast_set<int>(type_desc->get_precision()), \ |
229 | 0 | cast_set<int>(type_desc->get_scale())); \ |
230 | 0 | slot_id_to_value_range[slot->id()] = std::move(range); \ |
231 | 0 | break; \ |
232 | 0 | } |
233 | 0 | #define APPLY_FOR_SCALAR_TYPE(M) \ |
234 | 0 | M(TINYINT) \ |
235 | 0 | M(SMALLINT) \ |
236 | 0 | M(INT) \ |
237 | 0 | M(BIGINT) \ |
238 | 0 | M(LARGEINT) \ |
239 | 0 | M(FLOAT) \ |
240 | 0 | M(DOUBLE) \ |
241 | 0 | M(CHAR) \ |
242 | 0 | M(DATE) \ |
243 | 0 | M(DATETIME) \ |
244 | 0 | M(DATEV2) \ |
245 | 0 | M(DATETIMEV2) \ |
246 | 0 | M(TIMESTAMPTZ) \ |
247 | 0 | M(VARCHAR) \ |
248 | 0 | M(STRING) \ |
249 | 0 | M(DECIMAL32) \ |
250 | 0 | M(DECIMAL64) \ |
251 | 0 | M(DECIMAL128I) \ |
252 | 0 | M(DECIMAL256) \ |
253 | 0 | M(DECIMALV2) \ |
254 | 0 | M(BOOLEAN) \ |
255 | 0 | M(IPV4) \ |
256 | 0 | M(IPV6) |
257 | 0 | APPLY_FOR_SCALAR_TYPE(M) |
258 | 0 | #undef M |
259 | 0 | default: { |
260 | 0 | break; |
261 | 0 | } |
262 | 0 | } |
263 | 0 | } |
264 | | |
265 | | /// Step 1 of the scan-key generation pipeline. |
266 | | /// |
267 | | /// Parse SQL WHERE conjuncts into per-column ColumnValueRange objects stored in |
268 | | /// _slot_id_to_value_range. Each ColumnValueRange captures all constraints on |
269 | | /// one column (fixed values from IN / =, or min/max bounds from < / <= / > / >=). |
270 | | /// |
271 | | /// Example – "WHERE k1 IN (1, 2) AND k2 >= 5 AND k2 < 10 AND v > 100": |
272 | | /// => ColumnValueRange<k1>: fixed_values = {1, 2} |
273 | | /// => ColumnValueRange<k2>: scope [5, 10) (low=5 >=, high=10 <) |
274 | | /// => ColumnValueRange<v>: scope (100, MAX] (low=100 >, high=MAX <=) |
275 | | /// The k1/k2 ranges will later become scan keys (since they're key columns); |
276 | | /// v's range stays as a residual predicate / olap filter. |
277 | | /// |
278 | | /// After this step, _build_key_ranges_and_filters() picks up the key-column |
279 | | /// ColumnValueRanges and feeds them to OlapScanKeys::extend_scan_key(). |
280 | | template <typename Derived> |
281 | 0 | Status ScanLocalState<Derived>::_normalize_conjuncts(RuntimeState* state) { |
282 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
283 | | // The conjuncts is always on output tuple, so use _output_tuple_desc; |
284 | 0 | std::vector<SlotDescriptor*> slots = p._output_tuple_desc->slots(); |
285 | |
|
286 | 0 | for (auto& slot : slots) { |
287 | 0 | init_slot_value_range(_slot_id_to_value_range, slot, slot->type()); |
288 | 0 | _slot_id_to_predicates.insert( |
289 | 0 | {slot->id(), std::vector<std::shared_ptr<ColumnPredicate>>()}); |
290 | 0 | } |
291 | |
|
292 | 0 | get_cast_types_for_variants(); |
293 | 0 | for (const auto& [colname, type] : _cast_types_for_variants) { |
294 | 0 | auto* slot = p._slot_id_to_slot_desc[p._colname_to_slot_id[colname]]; |
295 | 0 | init_slot_value_range(_slot_id_to_value_range, slot, type); |
296 | 0 | _slot_id_to_predicates.insert( |
297 | 0 | {slot->id(), std::vector<std::shared_ptr<ColumnPredicate>>()}); |
298 | 0 | } |
299 | |
|
300 | 0 | RETURN_IF_ERROR(_get_topn_filters(state)); |
301 | | |
302 | 0 | for (auto it = _conjuncts.begin(); it != _conjuncts.end();) { |
303 | 0 | auto& conjunct = *it; |
304 | 0 | if (conjunct->root()) { |
305 | 0 | VExprSPtr new_root; |
306 | 0 | RETURN_IF_ERROR(_normalize_predicate(conjunct.get(), conjunct->root(), new_root)); |
307 | 0 | if (new_root) { |
308 | 0 | conjunct->set_root(new_root); |
309 | 0 | if (_should_push_down_common_expr() && |
310 | 0 | VExpr::is_acting_on_a_slot(*(conjunct->root()))) { |
311 | 0 | _common_expr_ctxs_push_down.emplace_back(conjunct); |
312 | 0 | it = _conjuncts.erase(it); |
313 | 0 | continue; |
314 | 0 | } |
315 | 0 | } else { // All conjuncts are pushed down as predicate column |
316 | 0 | _stale_expr_ctxs.emplace_back( |
317 | 0 | conjunct); // avoid function context and constant str being freed |
318 | 0 | it = _conjuncts.erase(it); |
319 | 0 | continue; |
320 | 0 | } |
321 | 0 | } |
322 | 0 | ++it; |
323 | 0 | } |
324 | | |
325 | 0 | if (state->enable_profile()) { |
326 | 0 | custom_profile()->add_info_string("PushDownPredicates", |
327 | 0 | predicates_to_string(_slot_id_to_predicates)); |
328 | 0 | std::string message; |
329 | 0 | for (auto& conjunct : _conjuncts) { |
330 | 0 | if (conjunct->root()) { |
331 | 0 | if (!message.empty()) { |
332 | 0 | message += ", "; |
333 | 0 | } |
334 | 0 | message += conjunct->root()->debug_string(); |
335 | 0 | } |
336 | 0 | } |
337 | 0 | custom_profile()->add_info_string("RemainedPredicates", message); |
338 | 0 | } |
339 | |
|
340 | 0 | for (auto& it : _slot_id_to_value_range) { |
341 | 0 | std::visit( |
342 | 0 | [&](auto&& range) { |
343 | 0 | if (range.is_empty_value_range()) { |
344 | 0 | _eos = true; |
345 | 0 | _scan_dependency->set_ready(); |
346 | 0 | } |
347 | 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_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateEENKUlOT_E_clIRNS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaS6_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_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_ |
348 | 0 | it.second); |
349 | 0 | } |
350 | |
|
351 | 0 | return Status::OK(); |
352 | 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_16EsScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE20_normalize_conjunctsEPNS_12RuntimeStateE |
353 | | |
354 | | template <typename Derived> |
355 | | Status ScanLocalState<Derived>::_normalize_predicate(VExprContext* context, const VExprSPtr& root, |
356 | 105 | VExprSPtr& output_expr) { |
357 | 105 | auto expr_root = root->is_rf_wrapper() ? root->get_impl() : root; |
358 | 105 | PushDownType pdt = PushDownType::UNACCEPTABLE; |
359 | 105 | if (dynamic_cast<VirtualSlotRef*>(expr_root.get())) { |
360 | | // If the expr has virtual slot ref, we need to keep it in the tree. |
361 | 0 | output_expr = expr_root; |
362 | 0 | return Status::OK(); |
363 | 0 | } |
364 | | |
365 | 105 | SlotDescriptor* slot = nullptr; |
366 | 105 | ColumnValueRangeType* range = nullptr; |
367 | 105 | RETURN_IF_ERROR(_eval_const_conjuncts(context, &pdt)); |
368 | 105 | if (pdt == PushDownType::ACCEPTABLE) { |
369 | 2 | output_expr = nullptr; |
370 | 2 | return Status::OK(); |
371 | 2 | } |
372 | 103 | std::shared_ptr<VSlotRef> slotref; |
373 | 188 | for (const auto& child : expr_root->children()) { |
374 | 188 | if (VExpr::expr_without_cast(child)->node_type() != TExprNodeType::SLOT_REF) { |
375 | | // not a slot ref(column) |
376 | 87 | continue; |
377 | 87 | } |
378 | 101 | slotref = std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(child)); |
379 | 101 | } |
380 | 103 | if (_is_predicate_acting_on_slot(expr_root->children(), &slot, &range)) { |
381 | 99 | Status status = Status::OK(); |
382 | 99 | std::visit( |
383 | 99 | [&](auto& value_range) { |
384 | 99 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; |
385 | 99 | { |
386 | 99 | Defer attach_defer = [&]() { |
387 | 99 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { |
388 | 0 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); |
389 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( |
390 | 0 | rf_expr->filter_id(), |
391 | 0 | rf_expr->predicate_filtered_rows_counter(), |
392 | 0 | rf_expr->predicate_input_rows_counter(), |
393 | 0 | rf_expr->predicate_always_true_rows_counter(), |
394 | 0 | context->get_runtime_filter_selectivity()); |
395 | 0 | } |
396 | 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_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ENKUlvE_clEv Unexecuted instantiation: _ZZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_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 | 386 | 15 | Defer attach_defer = [&]() { | 387 | 15 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 0 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 0 | rf_expr->filter_id(), | 391 | 0 | rf_expr->predicate_filtered_rows_counter(), | 392 | 0 | rf_expr->predicate_input_rows_counter(), | 393 | 0 | rf_expr->predicate_always_true_rows_counter(), | 394 | 0 | context->get_runtime_filter_selectivity()); | 395 | 0 | } | 396 | 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 | 386 | 63 | Defer attach_defer = [&]() { | 387 | 63 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 0 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 0 | rf_expr->filter_id(), | 391 | 0 | rf_expr->predicate_filtered_rows_counter(), | 392 | 0 | rf_expr->predicate_input_rows_counter(), | 393 | 0 | rf_expr->predicate_always_true_rows_counter(), | 394 | 0 | context->get_runtime_filter_selectivity()); | 395 | 0 | } | 396 | 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 | 386 | 21 | Defer attach_defer = [&]() { | 387 | 21 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 0 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 0 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 0 | rf_expr->filter_id(), | 391 | 0 | rf_expr->predicate_filtered_rows_counter(), | 392 | 0 | rf_expr->predicate_input_rows_counter(), | 393 | 0 | rf_expr->predicate_always_true_rows_counter(), | 394 | 0 | context->get_runtime_filter_selectivity()); | 395 | 0 | } | 396 | 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 |
397 | 99 | switch (expr->node_type()) { |
398 | 10 | case TExprNodeType::IN_PRED: |
399 | 10 | RETURN_IF_PUSH_DOWN( |
400 | 10 | _normalize_in_predicate(context, expr, slot, |
401 | 10 | _slot_id_to_predicates[slot->id()], |
402 | 10 | value_range, &pdt), |
403 | 10 | status); |
404 | 10 | break; |
405 | 85 | case TExprNodeType::BINARY_PRED: |
406 | 85 | RETURN_IF_PUSH_DOWN( |
407 | 85 | _normalize_binary_predicate(context, expr, slot, |
408 | 85 | _slot_id_to_predicates[slot->id()], |
409 | 85 | value_range, &pdt), |
410 | 85 | status); |
411 | 85 | break; |
412 | 4 | case TExprNodeType::FUNCTION_CALL: |
413 | 4 | if (expr->is_topn_filter()) { |
414 | 0 | RETURN_IF_PUSH_DOWN( |
415 | 0 | _normalize_topn_filter(context, expr, slot, |
416 | 0 | _slot_id_to_predicates[slot->id()], |
417 | 0 | &pdt), |
418 | 0 | status); |
419 | 4 | } else { |
420 | 4 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( |
421 | 4 | context, expr, slot, |
422 | 4 | _slot_id_to_predicates[slot->id()], |
423 | 4 | value_range, &pdt), |
424 | 4 | status); |
425 | 4 | } |
426 | 4 | break; |
427 | 4 | case TExprNodeType::BITMAP_PRED: |
428 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bitmap_filter( |
429 | 0 | context, root, slot, |
430 | 0 | _slot_id_to_predicates[slot->id()], &pdt), |
431 | 0 | status); |
432 | 0 | break; |
433 | 0 | case TExprNodeType::BLOOM_PRED: |
434 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( |
435 | 0 | context, root, slot, |
436 | 0 | _slot_id_to_predicates[slot->id()], &pdt), |
437 | 0 | status); |
438 | 0 | break; |
439 | 0 | default: |
440 | 0 | break; |
441 | 99 | } |
442 | 99 | } |
443 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED |
444 | 99 | if (state()->enable_function_pushdown()) { |
445 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), |
446 | 0 | status); |
447 | 0 | } |
448 | 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_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE3EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE4EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE5EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE6EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE7EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE8EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE9EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE36EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE37EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE15EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE10EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE23EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE11EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE25EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE12EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE26EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE42EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE20EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE2EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE28EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE29EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_normalize_predicateEPNS_12VExprContextERKSt10shared_ptrINS_5VExprEERS7_ENKUlRT_E_clINS_16ColumnValueRangeILNS_13PrimitiveTypeE30EEEEEDaSC_ Unexecuted instantiation: _ZZN5doris14ScanLocalStateINS_16EsScanLocalStateEE20_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 | 383 | 15 | [&](auto& value_range) { | 384 | 15 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 385 | 15 | { | 386 | 15 | Defer attach_defer = [&]() { | 387 | 15 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 15 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 15 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 15 | rf_expr->filter_id(), | 391 | 15 | rf_expr->predicate_filtered_rows_counter(), | 392 | 15 | rf_expr->predicate_input_rows_counter(), | 393 | 15 | rf_expr->predicate_always_true_rows_counter(), | 394 | 15 | context->get_runtime_filter_selectivity()); | 395 | 15 | } | 396 | 15 | }; | 397 | 15 | switch (expr->node_type()) { | 398 | 6 | case TExprNodeType::IN_PRED: | 399 | 6 | RETURN_IF_PUSH_DOWN( | 400 | 6 | _normalize_in_predicate(context, expr, slot, | 401 | 6 | _slot_id_to_predicates[slot->id()], | 402 | 6 | value_range, &pdt), | 403 | 6 | status); | 404 | 6 | break; | 405 | 7 | case TExprNodeType::BINARY_PRED: | 406 | 7 | RETURN_IF_PUSH_DOWN( | 407 | 7 | _normalize_binary_predicate(context, expr, slot, | 408 | 7 | _slot_id_to_predicates[slot->id()], | 409 | 7 | value_range, &pdt), | 410 | 7 | status); | 411 | 7 | break; | 412 | 2 | case TExprNodeType::FUNCTION_CALL: | 413 | 2 | if (expr->is_topn_filter()) { | 414 | 0 | RETURN_IF_PUSH_DOWN( | 415 | 0 | _normalize_topn_filter(context, expr, slot, | 416 | 0 | _slot_id_to_predicates[slot->id()], | 417 | 0 | &pdt), | 418 | 0 | status); | 419 | 2 | } else { | 420 | 2 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 421 | 2 | context, expr, slot, | 422 | 2 | _slot_id_to_predicates[slot->id()], | 423 | 2 | value_range, &pdt), | 424 | 2 | status); | 425 | 2 | } | 426 | 2 | break; | 427 | 2 | case TExprNodeType::BITMAP_PRED: | 428 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bitmap_filter( | 429 | 0 | context, root, slot, | 430 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 431 | 0 | status); | 432 | 0 | break; | 433 | 0 | case TExprNodeType::BLOOM_PRED: | 434 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 435 | 0 | context, root, slot, | 436 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 437 | 0 | status); | 438 | 0 | break; | 439 | 0 | default: | 440 | 0 | break; | 441 | 15 | } | 442 | 15 | } | 443 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 444 | 15 | if (state()->enable_function_pushdown()) { | 445 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 446 | 0 | status); | 447 | 0 | } | 448 | 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 | 383 | 63 | [&](auto& value_range) { | 384 | 63 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 385 | 63 | { | 386 | 63 | Defer attach_defer = [&]() { | 387 | 63 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 63 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 63 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 63 | rf_expr->filter_id(), | 391 | 63 | rf_expr->predicate_filtered_rows_counter(), | 392 | 63 | rf_expr->predicate_input_rows_counter(), | 393 | 63 | rf_expr->predicate_always_true_rows_counter(), | 394 | 63 | context->get_runtime_filter_selectivity()); | 395 | 63 | } | 396 | 63 | }; | 397 | 63 | switch (expr->node_type()) { | 398 | 2 | case TExprNodeType::IN_PRED: | 399 | 2 | RETURN_IF_PUSH_DOWN( | 400 | 2 | _normalize_in_predicate(context, expr, slot, | 401 | 2 | _slot_id_to_predicates[slot->id()], | 402 | 2 | value_range, &pdt), | 403 | 2 | status); | 404 | 2 | break; | 405 | 60 | case TExprNodeType::BINARY_PRED: | 406 | 60 | RETURN_IF_PUSH_DOWN( | 407 | 60 | _normalize_binary_predicate(context, expr, slot, | 408 | 60 | _slot_id_to_predicates[slot->id()], | 409 | 60 | value_range, &pdt), | 410 | 60 | status); | 411 | 60 | break; | 412 | 1 | case TExprNodeType::FUNCTION_CALL: | 413 | 1 | if (expr->is_topn_filter()) { | 414 | 0 | RETURN_IF_PUSH_DOWN( | 415 | 0 | _normalize_topn_filter(context, expr, slot, | 416 | 0 | _slot_id_to_predicates[slot->id()], | 417 | 0 | &pdt), | 418 | 0 | status); | 419 | 1 | } else { | 420 | 1 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 421 | 1 | context, expr, slot, | 422 | 1 | _slot_id_to_predicates[slot->id()], | 423 | 1 | value_range, &pdt), | 424 | 1 | status); | 425 | 1 | } | 426 | 1 | break; | 427 | 1 | case TExprNodeType::BITMAP_PRED: | 428 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bitmap_filter( | 429 | 0 | context, root, slot, | 430 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 431 | 0 | status); | 432 | 0 | break; | 433 | 0 | case TExprNodeType::BLOOM_PRED: | 434 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 435 | 0 | context, root, slot, | 436 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 437 | 0 | status); | 438 | 0 | break; | 439 | 0 | default: | 440 | 0 | break; | 441 | 63 | } | 442 | 63 | } | 443 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 444 | 63 | if (state()->enable_function_pushdown()) { | 445 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 446 | 0 | status); | 447 | 0 | } | 448 | 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 | 383 | 21 | [&](auto& value_range) { | 384 | 21 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 385 | 21 | { | 386 | 21 | Defer attach_defer = [&]() { | 387 | 21 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 21 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 21 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 21 | rf_expr->filter_id(), | 391 | 21 | rf_expr->predicate_filtered_rows_counter(), | 392 | 21 | rf_expr->predicate_input_rows_counter(), | 393 | 21 | rf_expr->predicate_always_true_rows_counter(), | 394 | 21 | context->get_runtime_filter_selectivity()); | 395 | 21 | } | 396 | 21 | }; | 397 | 21 | switch (expr->node_type()) { | 398 | 2 | case TExprNodeType::IN_PRED: | 399 | 2 | RETURN_IF_PUSH_DOWN( | 400 | 2 | _normalize_in_predicate(context, expr, slot, | 401 | 2 | _slot_id_to_predicates[slot->id()], | 402 | 2 | value_range, &pdt), | 403 | 2 | status); | 404 | 2 | break; | 405 | 18 | case TExprNodeType::BINARY_PRED: | 406 | 18 | RETURN_IF_PUSH_DOWN( | 407 | 18 | _normalize_binary_predicate(context, expr, slot, | 408 | 18 | _slot_id_to_predicates[slot->id()], | 409 | 18 | value_range, &pdt), | 410 | 18 | status); | 411 | 18 | break; | 412 | 1 | case TExprNodeType::FUNCTION_CALL: | 413 | 1 | if (expr->is_topn_filter()) { | 414 | 0 | RETURN_IF_PUSH_DOWN( | 415 | 0 | _normalize_topn_filter(context, expr, slot, | 416 | 0 | _slot_id_to_predicates[slot->id()], | 417 | 0 | &pdt), | 418 | 0 | status); | 419 | 1 | } else { | 420 | 1 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 421 | 1 | context, expr, slot, | 422 | 1 | _slot_id_to_predicates[slot->id()], | 423 | 1 | value_range, &pdt), | 424 | 1 | status); | 425 | 1 | } | 426 | 1 | break; | 427 | 1 | case TExprNodeType::BITMAP_PRED: | 428 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bitmap_filter( | 429 | 0 | context, root, slot, | 430 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 431 | 0 | status); | 432 | 0 | break; | 433 | 0 | case TExprNodeType::BLOOM_PRED: | 434 | 0 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 435 | 0 | context, root, slot, | 436 | 0 | _slot_id_to_predicates[slot->id()], &pdt), | 437 | 0 | status); | 438 | 0 | break; | 439 | 0 | default: | 440 | 0 | break; | 441 | 21 | } | 442 | 21 | } | 443 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 444 | 21 | if (state()->enable_function_pushdown()) { | 445 | 0 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 446 | 0 | status); | 447 | 0 | } | 448 | 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_ |
449 | 99 | *range); |
450 | 99 | RETURN_IF_ERROR(status); |
451 | 99 | } |
452 | 103 | if (pdt == PushDownType::ACCEPTABLE && slotref != nullptr && |
453 | 103 | slotref->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { |
454 | | // remaining it in the expr tree, in order to filter by function if the pushdown |
455 | | // predicate is not applied |
456 | 0 | output_expr = expr_root; // remaining in conjunct tree |
457 | 0 | return Status::OK(); |
458 | 0 | } |
459 | | |
460 | 103 | if (pdt == PushDownType::ACCEPTABLE && _is_key_column(slot->col_name())) { |
461 | 96 | output_expr = nullptr; |
462 | 96 | return Status::OK(); |
463 | 96 | } else { |
464 | | // for PARTIAL_ACCEPTABLE and UNACCEPTABLE, do not remove expr from the tree |
465 | 7 | output_expr = root; |
466 | 7 | return Status::OK(); |
467 | 7 | } |
468 | 0 | output_expr = root; |
469 | 0 | return Status::OK(); |
470 | 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_16EsScanLocalStateEE20_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 | 356 | 105 | VExprSPtr& output_expr) { | 357 | 105 | auto expr_root = root->is_rf_wrapper() ? root->get_impl() : root; | 358 | 105 | PushDownType pdt = PushDownType::UNACCEPTABLE; | 359 | 105 | if (dynamic_cast<VirtualSlotRef*>(expr_root.get())) { | 360 | | // If the expr has virtual slot ref, we need to keep it in the tree. | 361 | 0 | output_expr = expr_root; | 362 | 0 | return Status::OK(); | 363 | 0 | } | 364 | | | 365 | 105 | SlotDescriptor* slot = nullptr; | 366 | 105 | ColumnValueRangeType* range = nullptr; | 367 | 105 | RETURN_IF_ERROR(_eval_const_conjuncts(context, &pdt)); | 368 | 105 | if (pdt == PushDownType::ACCEPTABLE) { | 369 | 2 | output_expr = nullptr; | 370 | 2 | return Status::OK(); | 371 | 2 | } | 372 | 103 | std::shared_ptr<VSlotRef> slotref; | 373 | 188 | for (const auto& child : expr_root->children()) { | 374 | 188 | if (VExpr::expr_without_cast(child)->node_type() != TExprNodeType::SLOT_REF) { | 375 | | // not a slot ref(column) | 376 | 87 | continue; | 377 | 87 | } | 378 | 101 | slotref = std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(child)); | 379 | 101 | } | 380 | 103 | if (_is_predicate_acting_on_slot(expr_root->children(), &slot, &range)) { | 381 | 99 | Status status = Status::OK(); | 382 | 99 | std::visit( | 383 | 99 | [&](auto& value_range) { | 384 | 99 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; | 385 | 99 | { | 386 | 99 | Defer attach_defer = [&]() { | 387 | 99 | if (pdt != PushDownType::UNACCEPTABLE && root->is_rf_wrapper()) { | 388 | 99 | auto* rf_expr = assert_cast<VRuntimeFilterWrapper*>(root.get()); | 389 | 99 | _slot_id_to_predicates[slot->id()].back()->attach_profile_counter( | 390 | 99 | rf_expr->filter_id(), | 391 | 99 | rf_expr->predicate_filtered_rows_counter(), | 392 | 99 | rf_expr->predicate_input_rows_counter(), | 393 | 99 | rf_expr->predicate_always_true_rows_counter(), | 394 | 99 | context->get_runtime_filter_selectivity()); | 395 | 99 | } | 396 | 99 | }; | 397 | 99 | switch (expr->node_type()) { | 398 | 99 | case TExprNodeType::IN_PRED: | 399 | 99 | RETURN_IF_PUSH_DOWN( | 400 | 99 | _normalize_in_predicate(context, expr, slot, | 401 | 99 | _slot_id_to_predicates[slot->id()], | 402 | 99 | value_range, &pdt), | 403 | 99 | status); | 404 | 99 | break; | 405 | 99 | case TExprNodeType::BINARY_PRED: | 406 | 99 | RETURN_IF_PUSH_DOWN( | 407 | 99 | _normalize_binary_predicate(context, expr, slot, | 408 | 99 | _slot_id_to_predicates[slot->id()], | 409 | 99 | value_range, &pdt), | 410 | 99 | status); | 411 | 99 | break; | 412 | 99 | case TExprNodeType::FUNCTION_CALL: | 413 | 99 | if (expr->is_topn_filter()) { | 414 | 99 | RETURN_IF_PUSH_DOWN( | 415 | 99 | _normalize_topn_filter(context, expr, slot, | 416 | 99 | _slot_id_to_predicates[slot->id()], | 417 | 99 | &pdt), | 418 | 99 | status); | 419 | 99 | } else { | 420 | 99 | RETURN_IF_PUSH_DOWN(_normalize_is_null_predicate( | 421 | 99 | context, expr, slot, | 422 | 99 | _slot_id_to_predicates[slot->id()], | 423 | 99 | value_range, &pdt), | 424 | 99 | status); | 425 | 99 | } | 426 | 99 | break; | 427 | 99 | case TExprNodeType::BITMAP_PRED: | 428 | 99 | RETURN_IF_PUSH_DOWN(_normalize_bitmap_filter( | 429 | 99 | context, root, slot, | 430 | 99 | _slot_id_to_predicates[slot->id()], &pdt), | 431 | 99 | status); | 432 | 99 | break; | 433 | 99 | case TExprNodeType::BLOOM_PRED: | 434 | 99 | RETURN_IF_PUSH_DOWN(_normalize_bloom_filter( | 435 | 99 | context, root, slot, | 436 | 99 | _slot_id_to_predicates[slot->id()], &pdt), | 437 | 99 | status); | 438 | 99 | break; | 439 | 99 | default: | 440 | 99 | break; | 441 | 99 | } | 442 | 99 | } | 443 | | // `node_type` of function filter is FUNCTION_CALL or COMPOUND_PRED | 444 | 99 | if (state()->enable_function_pushdown()) { | 445 | 99 | RETURN_IF_PUSH_DOWN(_normalize_function_filters(context, slot, &pdt), | 446 | 99 | status); | 447 | 99 | } | 448 | 99 | }, | 449 | 99 | *range); | 450 | 99 | RETURN_IF_ERROR(status); | 451 | 99 | } | 452 | 103 | if (pdt == PushDownType::ACCEPTABLE && slotref != nullptr && | 453 | 103 | slotref->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { | 454 | | // remaining it in the expr tree, in order to filter by function if the pushdown | 455 | | // predicate is not applied | 456 | 0 | output_expr = expr_root; // remaining in conjunct tree | 457 | 0 | return Status::OK(); | 458 | 0 | } | 459 | | | 460 | 103 | if (pdt == PushDownType::ACCEPTABLE && _is_key_column(slot->col_name())) { | 461 | 96 | output_expr = nullptr; | 462 | 96 | return Status::OK(); | 463 | 96 | } else { | 464 | | // for PARTIAL_ACCEPTABLE and UNACCEPTABLE, do not remove expr from the tree | 465 | 7 | output_expr = root; | 466 | 7 | return Status::OK(); | 467 | 7 | } | 468 | 0 | output_expr = root; | 469 | 0 | return Status::OK(); | 470 | 103 | } |
|
471 | | |
472 | | Status ScanLocalStateBase::_normalize_bloom_filter( |
473 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
474 | 0 | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, PushDownType* pdt) { |
475 | 0 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
476 | 0 | Defer defer = [&]() { |
477 | 0 | if (pred) { |
478 | 0 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
479 | 0 | predicates.emplace_back(pred); |
480 | 0 | } else { |
481 | | // If exception occurs during processing, do not push down |
482 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
483 | 0 | } |
484 | 0 | }; |
485 | 0 | DCHECK(TExprNodeType::BLOOM_PRED == root->node_type()); |
486 | 0 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; |
487 | 0 | DCHECK(expr->get_num_children() == 1); |
488 | 0 | DCHECK(root->is_rf_wrapper()); |
489 | 0 | *pdt = _should_push_down_bloom_filter(); |
490 | 0 | if (*pdt != PushDownType::UNACCEPTABLE) { |
491 | 0 | pred = create_bloom_filter_predicate( |
492 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
493 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT ? expr->get_child(0)->data_type() |
494 | 0 | : slot->type(), |
495 | 0 | expr->get_bloom_filter_func()); |
496 | 0 | } |
497 | 0 | return Status::OK(); |
498 | 0 | } |
499 | | |
500 | | Status ScanLocalStateBase::_normalize_topn_filter( |
501 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
502 | 0 | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, PushDownType* pdt) { |
503 | 0 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
504 | 0 | Defer defer = [&]() { |
505 | 0 | if (pred) { |
506 | 0 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
507 | 0 | predicates.emplace_back(pred); |
508 | 0 | } else { |
509 | | // If exception occurs during processing, do not push down |
510 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
511 | 0 | } |
512 | 0 | }; |
513 | 0 | DCHECK(root->is_topn_filter()); |
514 | 0 | *pdt = _should_push_down_topn_filter(); |
515 | 0 | if (*pdt != PushDownType::UNACCEPTABLE) { |
516 | 0 | auto& tmp = _state->get_query_ctx()->get_runtime_predicate( |
517 | 0 | assert_cast<VTopNPred*>(root.get())->source_node_id()); |
518 | 0 | if (_push_down_topn(tmp)) { |
519 | 0 | pred = tmp.get_predicate(_parent->node_id()); |
520 | 0 | } |
521 | 0 | } |
522 | 0 | return Status::OK(); |
523 | 0 | } |
524 | | |
525 | | Status ScanLocalStateBase::_normalize_bitmap_filter( |
526 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
527 | 0 | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, PushDownType* pdt) { |
528 | 0 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
529 | 0 | Defer defer = [&]() { |
530 | 0 | if (pred) { |
531 | 0 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
532 | 0 | predicates.emplace_back(pred); |
533 | 0 | } else { |
534 | | // If exception occurs during processing, do not push down |
535 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
536 | 0 | } |
537 | 0 | }; |
538 | 0 | DCHECK(TExprNodeType::BITMAP_PRED == root->node_type()); |
539 | 0 | auto expr = root->is_rf_wrapper() ? root->get_impl() : root; |
540 | 0 | *pdt = _should_push_down_bitmap_filter(); |
541 | 0 | if (*pdt != PushDownType::UNACCEPTABLE) { |
542 | 0 | DCHECK(expr->get_num_children() == 1); |
543 | 0 | DCHECK(root->is_rf_wrapper()); |
544 | 0 | pred = create_bitmap_filter_predicate( |
545 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
546 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT ? expr->get_child(0)->data_type() |
547 | 0 | : slot->type(), |
548 | 0 | expr->get_bitmap_filter_func()); |
549 | 0 | } |
550 | 0 | return Status::OK(); |
551 | 0 | } |
552 | | |
553 | | Status ScanLocalStateBase::_normalize_function_filters(VExprContext* expr_ctx, SlotDescriptor* slot, |
554 | 0 | PushDownType* pdt) { |
555 | 0 | auto expr = expr_ctx->root()->is_rf_wrapper() ? expr_ctx->root()->get_impl() : expr_ctx->root(); |
556 | 0 | bool opposite = false; |
557 | 0 | VExpr* fn_expr = expr.get(); |
558 | 0 | if (TExprNodeType::COMPOUND_PRED == expr->node_type() && |
559 | 0 | expr->fn().name.function_name == "not") { |
560 | 0 | fn_expr = fn_expr->children()[0].get(); |
561 | 0 | opposite = true; |
562 | 0 | } |
563 | |
|
564 | 0 | if (fn_expr->is_like_expr()) { |
565 | 0 | doris::FunctionContext* fn_ctx = nullptr; |
566 | 0 | StringRef val; |
567 | 0 | PushDownType temp_pdt; |
568 | 0 | RETURN_IF_ERROR(_should_push_down_function_filter(assert_cast<VectorizedFnCall*>(fn_expr), |
569 | 0 | expr_ctx, &val, &fn_ctx, temp_pdt)); |
570 | 0 | if (temp_pdt != PushDownType::UNACCEPTABLE) { |
571 | 0 | std::string col = slot->col_name(); |
572 | 0 | _push_down_functions.emplace_back(opposite, col, fn_ctx, val); |
573 | 0 | *pdt = temp_pdt; |
574 | 0 | } |
575 | 0 | } |
576 | 0 | return Status::OK(); |
577 | 0 | } |
578 | | |
579 | | // only one level cast expr could push down for variant type |
580 | | // check if expr is cast and it's children is slot |
581 | 0 | static bool is_valid_push_down_cast(const VExprSPtrs& children) { |
582 | 0 | auto slot_expr = VExpr::expr_without_cast(children[0]); |
583 | 0 | return slot_expr->data_type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT && |
584 | 0 | children[0]->node_type() == TExprNodeType::CAST_EXPR && |
585 | 0 | children[0]->children().at(0)->is_slot_ref(); |
586 | 0 | } |
587 | | |
588 | | template <typename Derived> |
589 | | bool ScanLocalState<Derived>::_is_predicate_acting_on_slot(const VExprSPtrs& children, |
590 | | SlotDescriptor** slot_desc, |
591 | 103 | ColumnValueRangeType** range) { |
592 | | // children[0] must be slot ref or cast(slot(variant) as type) |
593 | 103 | if (children.empty() || (children[0]->node_type() != TExprNodeType::SLOT_REF && |
594 | 101 | !is_valid_push_down_cast(children))) { |
595 | | // not a slot ref(column) |
596 | 2 | return false; |
597 | 2 | } |
598 | 101 | std::shared_ptr<VSlotRef> slot_ref = |
599 | 101 | std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(children[0])); |
600 | 101 | *slot_desc = |
601 | 101 | _parent->cast<typename Derived::Parent>()._slot_id_to_slot_desc[slot_ref->slot_id()]; |
602 | 101 | auto entry = _slot_id_to_predicates.find(slot_ref->slot_id()); |
603 | 101 | if (_slot_id_to_predicates.end() == entry) { |
604 | 2 | return false; |
605 | 2 | } |
606 | 99 | auto sid_to_range = _slot_id_to_value_range.find(slot_ref->slot_id()); |
607 | 99 | if (_slot_id_to_value_range.end() == sid_to_range) { |
608 | 0 | return false; |
609 | 0 | } |
610 | 99 | if (remove_nullable((*slot_desc)->type())->get_primitive_type() == TYPE_VARBINARY) { |
611 | 0 | return false; |
612 | 0 | } |
613 | 99 | *range = &(sid_to_range->second); |
614 | 99 | return true; |
615 | 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_16EsScanLocalStateEE28_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 | 591 | 103 | ColumnValueRangeType** range) { | 592 | | // children[0] must be slot ref or cast(slot(variant) as type) | 593 | 103 | if (children.empty() || (children[0]->node_type() != TExprNodeType::SLOT_REF && | 594 | 101 | !is_valid_push_down_cast(children))) { | 595 | | // not a slot ref(column) | 596 | 2 | return false; | 597 | 2 | } | 598 | 101 | std::shared_ptr<VSlotRef> slot_ref = | 599 | 101 | std::dynamic_pointer_cast<VSlotRef>(VExpr::expr_without_cast(children[0])); | 600 | 101 | *slot_desc = | 601 | 101 | _parent->cast<typename Derived::Parent>()._slot_id_to_slot_desc[slot_ref->slot_id()]; | 602 | 101 | auto entry = _slot_id_to_predicates.find(slot_ref->slot_id()); | 603 | 101 | if (_slot_id_to_predicates.end() == entry) { | 604 | 2 | return false; | 605 | 2 | } | 606 | 99 | auto sid_to_range = _slot_id_to_value_range.find(slot_ref->slot_id()); | 607 | 99 | if (_slot_id_to_value_range.end() == sid_to_range) { | 608 | 0 | return false; | 609 | 0 | } | 610 | 99 | if (remove_nullable((*slot_desc)->type())->get_primitive_type() == TYPE_VARBINARY) { | 611 | 0 | return false; | 612 | 0 | } | 613 | 99 | *range = &(sid_to_range->second); | 614 | 99 | return true; | 615 | 99 | } |
|
616 | | |
617 | | template <typename Derived> |
618 | 0 | std::string ScanLocalState<Derived>::debug_string(int indentation_level) const { |
619 | 0 | fmt::memory_buffer debug_string_buffer; |
620 | 0 | fmt::format_to(debug_string_buffer, "{}, _eos = {} , _opened = {}", |
621 | 0 | PipelineXLocalState<>::debug_string(indentation_level), _eos.load(), |
622 | 0 | _opened.load()); |
623 | 0 | if (auto ctx = _scanner_ctx.load()) { |
624 | 0 | fmt::format_to(debug_string_buffer, ""); |
625 | 0 | fmt::format_to(debug_string_buffer, ", Scanner Context: {}", ctx->debug_string()); |
626 | 0 | } else { |
627 | 0 | fmt::format_to(debug_string_buffer, ""); |
628 | 0 | fmt::format_to(debug_string_buffer, ", Scanner Context: NULL"); |
629 | 0 | } |
630 | |
|
631 | 0 | return fmt::to_string(debug_string_buffer); |
632 | 0 | } Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_16EsScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE12debug_stringB5cxx11Ei Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE12debug_stringB5cxx11Ei |
633 | | |
634 | 105 | Status ScanLocalStateBase::_eval_const_conjuncts(VExprContext* expr_ctx, PushDownType* pdt) { |
635 | 105 | auto vexpr = |
636 | 105 | expr_ctx->root()->is_rf_wrapper() ? expr_ctx->root()->get_impl() : expr_ctx->root(); |
637 | | // Used to handle constant expressions, such as '1 = 1' _eval_const_conjuncts does not handle cases like 'colA = 1' |
638 | 105 | const char* constant_val = nullptr; |
639 | 105 | if (vexpr->is_constant()) { |
640 | 3 | std::shared_ptr<ColumnPtrWrapper> const_col_wrapper; |
641 | 3 | RETURN_IF_ERROR(vexpr->get_const_col(expr_ctx, &const_col_wrapper)); |
642 | 3 | if (const auto* const_column = |
643 | 3 | check_and_get_column<ColumnConst>(const_col_wrapper->column_ptr.get())) { |
644 | 1 | constant_val = const_column->get_data_at(0).data; |
645 | 1 | if (constant_val == nullptr || !*reinterpret_cast<const bool*>(constant_val)) { |
646 | 1 | *pdt = PushDownType::ACCEPTABLE; |
647 | 1 | _eos = true; |
648 | 1 | _scan_dependency->set_ready(); |
649 | 1 | } |
650 | 2 | } else if (const auto* bool_column = |
651 | 2 | check_and_get_column<ColumnUInt8>(const_col_wrapper->column_ptr.get())) { |
652 | | // TODO: If `vexpr->is_constant()` is true, a const column is expected here. |
653 | | // But now we still don't cover all predicates for const expression. |
654 | | // For example, for query `SELECT col FROM tbl WHERE 'PROMOTION' LIKE 'AAA%'`, |
655 | | // predicate `like` will return a ColumnVector<UInt8> which contains a single value. |
656 | 1 | LOG(WARNING) << "VExpr[" << vexpr->debug_string() |
657 | 1 | << "] should return a const column but actually is " |
658 | 1 | << const_col_wrapper->column_ptr->get_name(); |
659 | 1 | DCHECK_EQ(bool_column->size(), 1); |
660 | | /// TODO: There is a DCHECK here, but an additional check is still needed. It should return an error code. |
661 | 1 | if (bool_column->size() == 1) { |
662 | 1 | constant_val = bool_column->get_data_at(0).data; |
663 | 1 | if (constant_val == nullptr || !*reinterpret_cast<const bool*>(constant_val)) { |
664 | 1 | *pdt = PushDownType::ACCEPTABLE; |
665 | 1 | _eos = true; |
666 | 1 | _scan_dependency->set_ready(); |
667 | 1 | } |
668 | 1 | } else { |
669 | 0 | LOG(WARNING) << "Constant predicate in scan node should return a bool column with " |
670 | 0 | "`size == 1` but actually is " |
671 | 0 | << bool_column->size(); |
672 | 0 | } |
673 | 1 | } else { |
674 | 1 | LOG(WARNING) << "VExpr[" << vexpr->debug_string() |
675 | 1 | << "] should return a const column but actually is " |
676 | 1 | << const_col_wrapper->column_ptr->get_name(); |
677 | 1 | } |
678 | 3 | } |
679 | 105 | return Status::OK(); |
680 | 105 | } |
681 | | |
682 | | template <PrimitiveType T> |
683 | | Status ScanLocalStateBase::_normalize_in_predicate( |
684 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
685 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
686 | 10 | PushDownType* pdt) { |
687 | 10 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
688 | 10 | Defer defer = [&]() { |
689 | 10 | if (pred) { |
690 | 8 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
691 | 8 | predicates.emplace_back(pred); |
692 | 8 | } else { |
693 | | // If exception occurs during processing, do not push down |
694 | 2 | *pdt = PushDownType::UNACCEPTABLE; |
695 | 2 | } |
696 | 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 | 688 | 6 | Defer defer = [&]() { | 689 | 6 | if (pred) { | 690 | 4 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 4 | predicates.emplace_back(pred); | 692 | 4 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 2 | } | 696 | 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 | 688 | 2 | Defer defer = [&]() { | 689 | 2 | if (pred) { | 690 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 2 | predicates.emplace_back(pred); | 692 | 2 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 0 | } | 696 | 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 | 688 | 2 | Defer defer = [&]() { | 689 | 2 | if (pred) { | 690 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 2 | predicates.emplace_back(pred); | 692 | 2 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 0 | } | 696 | 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 |
697 | | |
698 | 10 | if (slot->get_virtual_column_expr() != nullptr) { |
699 | | // virtual column, do not push down |
700 | 0 | return Status::OK(); |
701 | 0 | } |
702 | | |
703 | 10 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
704 | 10 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); |
705 | 10 | *pdt = _should_push_down_in_predicate(); |
706 | 10 | if (*pdt == PushDownType::UNACCEPTABLE) { |
707 | 0 | return Status::OK(); |
708 | 0 | } |
709 | 10 | HybridSetBase::IteratorBase* iter = nullptr; |
710 | 10 | auto hybrid_set = root->get_set_func(); |
711 | | |
712 | 10 | auto is_in = false; |
713 | 10 | if (hybrid_set != nullptr) { |
714 | | // runtime filter produce VDirectInPredicate |
715 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { |
716 | 0 | iter = hybrid_set->begin(); |
717 | 0 | } |
718 | 0 | is_in = true; |
719 | 10 | } else { |
720 | | // normal in predicate |
721 | 10 | auto* tmp = assert_cast<VInPredicate*>(root.get()); |
722 | | |
723 | | // begin to push InPredicate value into ColumnValueRange |
724 | 10 | auto* state = reinterpret_cast<InState*>( |
725 | 10 | expr_ctx->fn_context(tmp->fn_context_index()) |
726 | 10 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); |
727 | | |
728 | | // xx in (col, xx, xx) should not be push down |
729 | 10 | if (!state->use_set) { |
730 | 1 | return Status::OK(); |
731 | 1 | } |
732 | 9 | is_in = !tmp->is_not_in(); |
733 | | |
734 | 9 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { |
735 | 1 | _eos = true; |
736 | 1 | _scan_dependency->set_ready(); |
737 | 1 | return Status::OK(); |
738 | 1 | } |
739 | 8 | hybrid_set = state->hybrid_set; |
740 | 8 | iter = state->hybrid_set->begin(); |
741 | 8 | } |
742 | | |
743 | 8 | if (iter) { |
744 | 8 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( |
745 | 8 | slot->is_nullable(), range.precision(), range.scale()); |
746 | 8 | auto& temp_range = is_in ? empty_range : range; |
747 | 8 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range |
748 | 8 | : (range.is_fixed_value_range() |
749 | 4 | ? ColumnValueRange<T>::remove_fixed_value_range |
750 | 4 | : ColumnValueRange<T>::empty_function); |
751 | 46 | while (iter->has_next()) { |
752 | | // column in (nullptr) is always false so continue to |
753 | | // dispose next item |
754 | 38 | DCHECK(iter->get_value() != nullptr); |
755 | 38 | const auto* value = iter->get_value(); |
756 | 38 | if constexpr (is_string_type(T)) { |
757 | 0 | const auto* str_value = reinterpret_cast<const StringRef*>(value); |
758 | 0 | RETURN_IF_ERROR(_change_value_range( |
759 | 0 | is_in, temp_range, |
760 | 0 | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, |
761 | 0 | is_in ? "in" : "not_in")); |
762 | 38 | } else { |
763 | 38 | RETURN_IF_ERROR(_change_value_range( |
764 | 38 | is_in, temp_range, |
765 | 38 | Field::create_field<T>( |
766 | 38 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( |
767 | 38 | value)), |
768 | 38 | fn, is_in ? "in" : "not_in")); |
769 | 38 | } |
770 | 38 | iter->next(); |
771 | 38 | } |
772 | 8 | if (is_in) { |
773 | 4 | range.intersection(temp_range); |
774 | 4 | } |
775 | 8 | } |
776 | 8 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( |
777 | 4 | _parent->intermediate_row_desc().get_column_id(slot->id()), |
778 | 4 | slot->col_name(), |
779 | 4 | slot->type()->get_primitive_type() == TYPE_VARIANT |
780 | 4 | ? root->get_child(0)->data_type() |
781 | 4 | : slot->type(), |
782 | 4 | hybrid_set, false) |
783 | 8 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( |
784 | 4 | _parent->intermediate_row_desc().get_column_id(slot->id()), |
785 | 4 | slot->col_name(), |
786 | 4 | slot->type()->get_primitive_type() == TYPE_VARIANT |
787 | 4 | ? root->get_child(0)->data_type() |
788 | 4 | : slot->type(), |
789 | 4 | hybrid_set, false); |
790 | 8 | return Status::OK(); |
791 | 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 | 686 | 6 | PushDownType* pdt) { | 687 | 6 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 688 | 6 | Defer defer = [&]() { | 689 | 6 | if (pred) { | 690 | 6 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 6 | predicates.emplace_back(pred); | 692 | 6 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 6 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 6 | } | 696 | 6 | }; | 697 | | | 698 | 6 | if (slot->get_virtual_column_expr() != nullptr) { | 699 | | // virtual column, do not push down | 700 | 0 | return Status::OK(); | 701 | 0 | } | 702 | | | 703 | 6 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 704 | 6 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 705 | 6 | *pdt = _should_push_down_in_predicate(); | 706 | 6 | if (*pdt == PushDownType::UNACCEPTABLE) { | 707 | 0 | return Status::OK(); | 708 | 0 | } | 709 | 6 | HybridSetBase::IteratorBase* iter = nullptr; | 710 | 6 | auto hybrid_set = root->get_set_func(); | 711 | | | 712 | 6 | auto is_in = false; | 713 | 6 | if (hybrid_set != nullptr) { | 714 | | // runtime filter produce VDirectInPredicate | 715 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 716 | 0 | iter = hybrid_set->begin(); | 717 | 0 | } | 718 | 0 | is_in = true; | 719 | 6 | } else { | 720 | | // normal in predicate | 721 | 6 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 722 | | | 723 | | // begin to push InPredicate value into ColumnValueRange | 724 | 6 | auto* state = reinterpret_cast<InState*>( | 725 | 6 | expr_ctx->fn_context(tmp->fn_context_index()) | 726 | 6 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 727 | | | 728 | | // xx in (col, xx, xx) should not be push down | 729 | 6 | if (!state->use_set) { | 730 | 1 | return Status::OK(); | 731 | 1 | } | 732 | 5 | is_in = !tmp->is_not_in(); | 733 | | | 734 | 5 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 735 | 1 | _eos = true; | 736 | 1 | _scan_dependency->set_ready(); | 737 | 1 | return Status::OK(); | 738 | 1 | } | 739 | 4 | hybrid_set = state->hybrid_set; | 740 | 4 | iter = state->hybrid_set->begin(); | 741 | 4 | } | 742 | | | 743 | 4 | if (iter) { | 744 | 4 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 745 | 4 | slot->is_nullable(), range.precision(), range.scale()); | 746 | 4 | auto& temp_range = is_in ? empty_range : range; | 747 | 4 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 748 | 4 | : (range.is_fixed_value_range() | 749 | 2 | ? ColumnValueRange<T>::remove_fixed_value_range | 750 | 2 | : ColumnValueRange<T>::empty_function); | 751 | 16 | while (iter->has_next()) { | 752 | | // column in (nullptr) is always false so continue to | 753 | | // dispose next item | 754 | 12 | DCHECK(iter->get_value() != nullptr); | 755 | 12 | const auto* value = iter->get_value(); | 756 | | if constexpr (is_string_type(T)) { | 757 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 758 | | RETURN_IF_ERROR(_change_value_range( | 759 | | is_in, temp_range, | 760 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 761 | | is_in ? "in" : "not_in")); | 762 | 12 | } else { | 763 | 12 | RETURN_IF_ERROR(_change_value_range( | 764 | 12 | is_in, temp_range, | 765 | 12 | Field::create_field<T>( | 766 | 12 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 767 | 12 | value)), | 768 | 12 | fn, is_in ? "in" : "not_in")); | 769 | 12 | } | 770 | 12 | iter->next(); | 771 | 12 | } | 772 | 4 | if (is_in) { | 773 | 2 | range.intersection(temp_range); | 774 | 2 | } | 775 | 4 | } | 776 | 4 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 777 | 2 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 778 | 2 | slot->col_name(), | 779 | 2 | slot->type()->get_primitive_type() == TYPE_VARIANT | 780 | 2 | ? root->get_child(0)->data_type() | 781 | 2 | : slot->type(), | 782 | 2 | hybrid_set, false) | 783 | 4 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 784 | 2 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 785 | 2 | slot->col_name(), | 786 | 2 | slot->type()->get_primitive_type() == TYPE_VARIANT | 787 | 2 | ? root->get_child(0)->data_type() | 788 | 2 | : slot->type(), | 789 | 2 | hybrid_set, false); | 790 | 4 | return Status::OK(); | 791 | 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 | 686 | 2 | PushDownType* pdt) { | 687 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 688 | 2 | Defer defer = [&]() { | 689 | 2 | if (pred) { | 690 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 2 | predicates.emplace_back(pred); | 692 | 2 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 2 | } | 696 | 2 | }; | 697 | | | 698 | 2 | if (slot->get_virtual_column_expr() != nullptr) { | 699 | | // virtual column, do not push down | 700 | 0 | return Status::OK(); | 701 | 0 | } | 702 | | | 703 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 704 | 2 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 705 | 2 | *pdt = _should_push_down_in_predicate(); | 706 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 707 | 0 | return Status::OK(); | 708 | 0 | } | 709 | 2 | HybridSetBase::IteratorBase* iter = nullptr; | 710 | 2 | auto hybrid_set = root->get_set_func(); | 711 | | | 712 | 2 | auto is_in = false; | 713 | 2 | if (hybrid_set != nullptr) { | 714 | | // runtime filter produce VDirectInPredicate | 715 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 716 | 0 | iter = hybrid_set->begin(); | 717 | 0 | } | 718 | 0 | is_in = true; | 719 | 2 | } else { | 720 | | // normal in predicate | 721 | 2 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 722 | | | 723 | | // begin to push InPredicate value into ColumnValueRange | 724 | 2 | auto* state = reinterpret_cast<InState*>( | 725 | 2 | expr_ctx->fn_context(tmp->fn_context_index()) | 726 | 2 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 727 | | | 728 | | // xx in (col, xx, xx) should not be push down | 729 | 2 | if (!state->use_set) { | 730 | 0 | return Status::OK(); | 731 | 0 | } | 732 | 2 | is_in = !tmp->is_not_in(); | 733 | | | 734 | 2 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 735 | 0 | _eos = true; | 736 | 0 | _scan_dependency->set_ready(); | 737 | 0 | return Status::OK(); | 738 | 0 | } | 739 | 2 | hybrid_set = state->hybrid_set; | 740 | 2 | iter = state->hybrid_set->begin(); | 741 | 2 | } | 742 | | | 743 | 2 | if (iter) { | 744 | 2 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 745 | 2 | slot->is_nullable(), range.precision(), range.scale()); | 746 | 2 | auto& temp_range = is_in ? empty_range : range; | 747 | 2 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 748 | 2 | : (range.is_fixed_value_range() | 749 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 750 | 1 | : ColumnValueRange<T>::empty_function); | 751 | 22 | while (iter->has_next()) { | 752 | | // column in (nullptr) is always false so continue to | 753 | | // dispose next item | 754 | 20 | DCHECK(iter->get_value() != nullptr); | 755 | 20 | const auto* value = iter->get_value(); | 756 | | if constexpr (is_string_type(T)) { | 757 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 758 | | RETURN_IF_ERROR(_change_value_range( | 759 | | is_in, temp_range, | 760 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 761 | | is_in ? "in" : "not_in")); | 762 | 20 | } else { | 763 | 20 | RETURN_IF_ERROR(_change_value_range( | 764 | 20 | is_in, temp_range, | 765 | 20 | Field::create_field<T>( | 766 | 20 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 767 | 20 | value)), | 768 | 20 | fn, is_in ? "in" : "not_in")); | 769 | 20 | } | 770 | 20 | iter->next(); | 771 | 20 | } | 772 | 2 | if (is_in) { | 773 | 1 | range.intersection(temp_range); | 774 | 1 | } | 775 | 2 | } | 776 | 2 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 777 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 778 | 1 | slot->col_name(), | 779 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 780 | 1 | ? root->get_child(0)->data_type() | 781 | 1 | : slot->type(), | 782 | 1 | hybrid_set, false) | 783 | 2 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 784 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 785 | 1 | slot->col_name(), | 786 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 787 | 1 | ? root->get_child(0)->data_type() | 788 | 1 | : slot->type(), | 789 | 1 | hybrid_set, false); | 790 | 2 | return Status::OK(); | 791 | 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 | 686 | 2 | PushDownType* pdt) { | 687 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 688 | 2 | Defer defer = [&]() { | 689 | 2 | if (pred) { | 690 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 691 | 2 | predicates.emplace_back(pred); | 692 | 2 | } else { | 693 | | // If exception occurs during processing, do not push down | 694 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 695 | 2 | } | 696 | 2 | }; | 697 | | | 698 | 2 | if (slot->get_virtual_column_expr() != nullptr) { | 699 | | // virtual column, do not push down | 700 | 0 | return Status::OK(); | 701 | 0 | } | 702 | | | 703 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 704 | 2 | DCHECK(TExprNodeType::IN_PRED == root->node_type()) << root->debug_string(); | 705 | 2 | *pdt = _should_push_down_in_predicate(); | 706 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 707 | 0 | return Status::OK(); | 708 | 0 | } | 709 | 2 | HybridSetBase::IteratorBase* iter = nullptr; | 710 | 2 | auto hybrid_set = root->get_set_func(); | 711 | | | 712 | 2 | auto is_in = false; | 713 | 2 | if (hybrid_set != nullptr) { | 714 | | // runtime filter produce VDirectInPredicate | 715 | 0 | if (hybrid_set->size() <= static_cast<size_t>(_max_pushdown_conditions_per_column)) { | 716 | 0 | iter = hybrid_set->begin(); | 717 | 0 | } | 718 | 0 | is_in = true; | 719 | 2 | } else { | 720 | | // normal in predicate | 721 | 2 | auto* tmp = assert_cast<VInPredicate*>(root.get()); | 722 | | | 723 | | // begin to push InPredicate value into ColumnValueRange | 724 | 2 | auto* state = reinterpret_cast<InState*>( | 725 | 2 | expr_ctx->fn_context(tmp->fn_context_index()) | 726 | 2 | ->get_function_state(FunctionContext::FRAGMENT_LOCAL)); | 727 | | | 728 | | // xx in (col, xx, xx) should not be push down | 729 | 2 | if (!state->use_set) { | 730 | 0 | return Status::OK(); | 731 | 0 | } | 732 | 2 | is_in = !tmp->is_not_in(); | 733 | | | 734 | 2 | if (state->hybrid_set->contain_null() && tmp->is_not_in()) { | 735 | 0 | _eos = true; | 736 | 0 | _scan_dependency->set_ready(); | 737 | 0 | return Status::OK(); | 738 | 0 | } | 739 | 2 | hybrid_set = state->hybrid_set; | 740 | 2 | iter = state->hybrid_set->begin(); | 741 | 2 | } | 742 | | | 743 | 2 | if (iter) { | 744 | 2 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 745 | 2 | slot->is_nullable(), range.precision(), range.scale()); | 746 | 2 | auto& temp_range = is_in ? empty_range : range; | 747 | 2 | auto fn = is_in ? ColumnValueRange<T>::add_fixed_value_range | 748 | 2 | : (range.is_fixed_value_range() | 749 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 750 | 1 | : ColumnValueRange<T>::empty_function); | 751 | 8 | while (iter->has_next()) { | 752 | | // column in (nullptr) is always false so continue to | 753 | | // dispose next item | 754 | 6 | DCHECK(iter->get_value() != nullptr); | 755 | 6 | const auto* value = iter->get_value(); | 756 | | if constexpr (is_string_type(T)) { | 757 | | const auto* str_value = reinterpret_cast<const StringRef*>(value); | 758 | | RETURN_IF_ERROR(_change_value_range( | 759 | | is_in, temp_range, | 760 | | Field::create_field<T>(std::string(str_value->data, str_value->size)), fn, | 761 | | is_in ? "in" : "not_in")); | 762 | 6 | } else { | 763 | 6 | RETURN_IF_ERROR(_change_value_range( | 764 | 6 | is_in, temp_range, | 765 | 6 | Field::create_field<T>( | 766 | 6 | *reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>( | 767 | 6 | value)), | 768 | 6 | fn, is_in ? "in" : "not_in")); | 769 | 6 | } | 770 | 6 | iter->next(); | 771 | 6 | } | 772 | 2 | if (is_in) { | 773 | 1 | range.intersection(temp_range); | 774 | 1 | } | 775 | 2 | } | 776 | 2 | pred = is_in ? create_in_list_predicate<PredicateType::IN_LIST>( | 777 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 778 | 1 | slot->col_name(), | 779 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 780 | 1 | ? root->get_child(0)->data_type() | 781 | 1 | : slot->type(), | 782 | 1 | hybrid_set, false) | 783 | 2 | : create_in_list_predicate<PredicateType::NOT_IN_LIST>( | 784 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), | 785 | 1 | slot->col_name(), | 786 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 787 | 1 | ? root->get_child(0)->data_type() | 788 | 1 | : slot->type(), | 789 | 1 | hybrid_set, false); | 790 | 2 | return Status::OK(); | 791 | 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 |
792 | | |
793 | | template <PrimitiveType T> |
794 | | Status ScanLocalStateBase::_normalize_binary_predicate( |
795 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
796 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
797 | 85 | PushDownType* pdt) { |
798 | 85 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
799 | 85 | Defer defer = [&]() { |
800 | 85 | if (pred) { |
801 | 84 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
802 | 84 | predicates.emplace_back(pred); |
803 | 84 | } else { |
804 | | // If exception occurs during processing, do not push down |
805 | 1 | *pdt = PushDownType::UNACCEPTABLE; |
806 | 1 | } |
807 | 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 | 799 | 7 | Defer defer = [&]() { | 800 | 7 | if (pred) { | 801 | 6 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 6 | predicates.emplace_back(pred); | 803 | 6 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 1 | } | 807 | 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 | 799 | 60 | Defer defer = [&]() { | 800 | 60 | if (pred) { | 801 | 60 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 60 | predicates.emplace_back(pred); | 803 | 60 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 0 | } | 807 | 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 | 799 | 18 | Defer defer = [&]() { | 800 | 18 | if (pred) { | 801 | 18 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 18 | predicates.emplace_back(pred); | 803 | 18 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 0 | } | 807 | 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 |
808 | | |
809 | 85 | if (slot->get_virtual_column_expr() != nullptr) { |
810 | | // virtual column, do not push down |
811 | 0 | return Status::OK(); |
812 | 0 | } |
813 | | |
814 | 85 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
815 | 85 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); |
816 | 85 | DCHECK(root->get_num_children() == 2); |
817 | 85 | Field value; |
818 | 85 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, |
819 | 85 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); |
820 | 85 | if (*pdt == PushDownType::UNACCEPTABLE) { |
821 | 0 | return Status::OK(); |
822 | 0 | } |
823 | 85 | const std::string& function_name = |
824 | 85 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; |
825 | 85 | auto op = to_olap_filter_type(function_name); |
826 | 85 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; |
827 | 85 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( |
828 | 85 | slot->is_nullable(), range.precision(), range.scale()); |
829 | 85 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; |
830 | 85 | if (value.get_type() != TYPE_NULL) { |
831 | 84 | switch (op) { |
832 | 16 | case SQLFilterOp::FILTER_EQ: |
833 | 16 | pred = create_comparison_predicate<PredicateType::EQ>( |
834 | 16 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
835 | 16 | slot->type()->get_primitive_type() == TYPE_VARIANT |
836 | 16 | ? root->get_child(0)->data_type() |
837 | 16 | : slot->type(), |
838 | 16 | value, false); |
839 | 16 | break; |
840 | 14 | case SQLFilterOp::FILTER_NE: |
841 | 14 | pred = create_comparison_predicate<PredicateType::NE>( |
842 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
843 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
844 | 14 | ? root->get_child(0)->data_type() |
845 | 14 | : slot->type(), |
846 | 14 | value, false); |
847 | 14 | break; |
848 | 13 | case SQLFilterOp::FILTER_LESS: |
849 | 13 | pred = create_comparison_predicate<PredicateType::LT>( |
850 | 13 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
851 | 13 | slot->type()->get_primitive_type() == TYPE_VARIANT |
852 | 13 | ? root->get_child(0)->data_type() |
853 | 13 | : slot->type(), |
854 | 13 | value, false); |
855 | 13 | break; |
856 | 13 | case SQLFilterOp::FILTER_LARGER: |
857 | 13 | pred = create_comparison_predicate<PredicateType::GT>( |
858 | 13 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
859 | 13 | slot->type()->get_primitive_type() == TYPE_VARIANT |
860 | 13 | ? root->get_child(0)->data_type() |
861 | 13 | : slot->type(), |
862 | 13 | value, false); |
863 | 13 | break; |
864 | 14 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: |
865 | 14 | pred = create_comparison_predicate<PredicateType::LE>( |
866 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
867 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
868 | 14 | ? root->get_child(0)->data_type() |
869 | 14 | : slot->type(), |
870 | 14 | value, false); |
871 | 14 | break; |
872 | 14 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: |
873 | 14 | pred = create_comparison_predicate<PredicateType::GE>( |
874 | 14 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), |
875 | 14 | slot->type()->get_primitive_type() == TYPE_VARIANT |
876 | 14 | ? root->get_child(0)->data_type() |
877 | 14 | : slot->type(), |
878 | 14 | value, false); |
879 | 14 | break; |
880 | 0 | default: |
881 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); |
882 | 84 | } |
883 | | |
884 | 84 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range |
885 | 84 | : op == SQLFilterOp::FILTER_NE |
886 | 68 | ? (range.is_fixed_value_range() |
887 | 14 | ? ColumnValueRange<T>::remove_fixed_value_range |
888 | 14 | : ColumnValueRange<T>::empty_function) |
889 | 68 | : ColumnValueRange<T>::add_value_range; |
890 | 84 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); |
891 | 84 | if (op == SQLFilterOp::FILTER_EQ) { |
892 | 16 | range.intersection(temp_range); |
893 | 16 | } |
894 | 84 | } else { |
895 | 1 | *pdt = PushDownType::UNACCEPTABLE; |
896 | 1 | _eos = true; |
897 | 1 | _scan_dependency->set_ready(); |
898 | 1 | } |
899 | | |
900 | 85 | return Status::OK(); |
901 | 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 | 797 | 7 | PushDownType* pdt) { | 798 | 7 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 799 | 7 | Defer defer = [&]() { | 800 | 7 | if (pred) { | 801 | 7 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 7 | predicates.emplace_back(pred); | 803 | 7 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 7 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 7 | } | 807 | 7 | }; | 808 | | | 809 | 7 | if (slot->get_virtual_column_expr() != nullptr) { | 810 | | // virtual column, do not push down | 811 | 0 | return Status::OK(); | 812 | 0 | } | 813 | | | 814 | 7 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 815 | 7 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 816 | 7 | DCHECK(root->get_num_children() == 2); | 817 | 7 | Field value; | 818 | 7 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 819 | 7 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 820 | 7 | if (*pdt == PushDownType::UNACCEPTABLE) { | 821 | 0 | return Status::OK(); | 822 | 0 | } | 823 | 7 | const std::string& function_name = | 824 | 7 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 825 | 7 | auto op = to_olap_filter_type(function_name); | 826 | 7 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 827 | 7 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 828 | 7 | slot->is_nullable(), range.precision(), range.scale()); | 829 | 7 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 830 | 7 | if (value.get_type() != TYPE_NULL) { | 831 | 6 | switch (op) { | 832 | 3 | case SQLFilterOp::FILTER_EQ: | 833 | 3 | pred = create_comparison_predicate<PredicateType::EQ>( | 834 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 835 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 836 | 3 | ? root->get_child(0)->data_type() | 837 | 3 | : slot->type(), | 838 | 3 | value, false); | 839 | 3 | break; | 840 | 1 | case SQLFilterOp::FILTER_NE: | 841 | 1 | pred = create_comparison_predicate<PredicateType::NE>( | 842 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 843 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 844 | 1 | ? root->get_child(0)->data_type() | 845 | 1 | : slot->type(), | 846 | 1 | value, false); | 847 | 1 | break; | 848 | 0 | case SQLFilterOp::FILTER_LESS: | 849 | 0 | pred = create_comparison_predicate<PredicateType::LT>( | 850 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 851 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT | 852 | 0 | ? root->get_child(0)->data_type() | 853 | 0 | : slot->type(), | 854 | 0 | value, false); | 855 | 0 | break; | 856 | 0 | case SQLFilterOp::FILTER_LARGER: | 857 | 0 | pred = create_comparison_predicate<PredicateType::GT>( | 858 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 859 | 0 | slot->type()->get_primitive_type() == TYPE_VARIANT | 860 | 0 | ? root->get_child(0)->data_type() | 861 | 0 | : slot->type(), | 862 | 0 | value, false); | 863 | 0 | break; | 864 | 1 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 865 | 1 | pred = create_comparison_predicate<PredicateType::LE>( | 866 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 867 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 868 | 1 | ? root->get_child(0)->data_type() | 869 | 1 | : slot->type(), | 870 | 1 | value, false); | 871 | 1 | break; | 872 | 1 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 873 | 1 | pred = create_comparison_predicate<PredicateType::GE>( | 874 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 875 | 1 | slot->type()->get_primitive_type() == TYPE_VARIANT | 876 | 1 | ? root->get_child(0)->data_type() | 877 | 1 | : slot->type(), | 878 | 1 | value, false); | 879 | 1 | break; | 880 | 0 | default: | 881 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 882 | 6 | } | 883 | | | 884 | 6 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 885 | 6 | : op == SQLFilterOp::FILTER_NE | 886 | 3 | ? (range.is_fixed_value_range() | 887 | 1 | ? ColumnValueRange<T>::remove_fixed_value_range | 888 | 1 | : ColumnValueRange<T>::empty_function) | 889 | 3 | : ColumnValueRange<T>::add_value_range; | 890 | 6 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 891 | 6 | if (op == SQLFilterOp::FILTER_EQ) { | 892 | 3 | range.intersection(temp_range); | 893 | 3 | } | 894 | 6 | } else { | 895 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 896 | 1 | _eos = true; | 897 | 1 | _scan_dependency->set_ready(); | 898 | 1 | } | 899 | | | 900 | 7 | return Status::OK(); | 901 | 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 | 797 | 60 | PushDownType* pdt) { | 798 | 60 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 799 | 60 | Defer defer = [&]() { | 800 | 60 | if (pred) { | 801 | 60 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 60 | predicates.emplace_back(pred); | 803 | 60 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 60 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 60 | } | 807 | 60 | }; | 808 | | | 809 | 60 | if (slot->get_virtual_column_expr() != nullptr) { | 810 | | // virtual column, do not push down | 811 | 0 | return Status::OK(); | 812 | 0 | } | 813 | | | 814 | 60 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 815 | 60 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 816 | 60 | DCHECK(root->get_num_children() == 2); | 817 | 60 | Field value; | 818 | 60 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 819 | 60 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 820 | 60 | if (*pdt == PushDownType::UNACCEPTABLE) { | 821 | 0 | return Status::OK(); | 822 | 0 | } | 823 | 60 | const std::string& function_name = | 824 | 60 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 825 | 60 | auto op = to_olap_filter_type(function_name); | 826 | 60 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 827 | 60 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 828 | 60 | slot->is_nullable(), range.precision(), range.scale()); | 829 | 60 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 830 | 60 | if (value.get_type() != TYPE_NULL) { | 831 | 60 | switch (op) { | 832 | 10 | case SQLFilterOp::FILTER_EQ: | 833 | 10 | pred = create_comparison_predicate<PredicateType::EQ>( | 834 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 835 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 836 | 10 | ? root->get_child(0)->data_type() | 837 | 10 | : slot->type(), | 838 | 10 | value, false); | 839 | 10 | break; | 840 | 10 | case SQLFilterOp::FILTER_NE: | 841 | 10 | pred = create_comparison_predicate<PredicateType::NE>( | 842 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 843 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 844 | 10 | ? root->get_child(0)->data_type() | 845 | 10 | : slot->type(), | 846 | 10 | value, false); | 847 | 10 | break; | 848 | 10 | case SQLFilterOp::FILTER_LESS: | 849 | 10 | pred = create_comparison_predicate<PredicateType::LT>( | 850 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 851 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 852 | 10 | ? root->get_child(0)->data_type() | 853 | 10 | : slot->type(), | 854 | 10 | value, false); | 855 | 10 | break; | 856 | 10 | case SQLFilterOp::FILTER_LARGER: | 857 | 10 | pred = create_comparison_predicate<PredicateType::GT>( | 858 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 859 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 860 | 10 | ? root->get_child(0)->data_type() | 861 | 10 | : slot->type(), | 862 | 10 | value, false); | 863 | 10 | break; | 864 | 10 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 865 | 10 | pred = create_comparison_predicate<PredicateType::LE>( | 866 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 867 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 868 | 10 | ? root->get_child(0)->data_type() | 869 | 10 | : slot->type(), | 870 | 10 | value, false); | 871 | 10 | break; | 872 | 10 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 873 | 10 | pred = create_comparison_predicate<PredicateType::GE>( | 874 | 10 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 875 | 10 | slot->type()->get_primitive_type() == TYPE_VARIANT | 876 | 10 | ? root->get_child(0)->data_type() | 877 | 10 | : slot->type(), | 878 | 10 | value, false); | 879 | 10 | break; | 880 | 0 | default: | 881 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 882 | 60 | } | 883 | | | 884 | 60 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 885 | 60 | : op == SQLFilterOp::FILTER_NE | 886 | 50 | ? (range.is_fixed_value_range() | 887 | 10 | ? ColumnValueRange<T>::remove_fixed_value_range | 888 | 10 | : ColumnValueRange<T>::empty_function) | 889 | 50 | : ColumnValueRange<T>::add_value_range; | 890 | 60 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 891 | 60 | if (op == SQLFilterOp::FILTER_EQ) { | 892 | 10 | range.intersection(temp_range); | 893 | 10 | } | 894 | 60 | } else { | 895 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 896 | 0 | _eos = true; | 897 | 0 | _scan_dependency->set_ready(); | 898 | 0 | } | 899 | | | 900 | 60 | return Status::OK(); | 901 | 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 | 797 | 18 | PushDownType* pdt) { | 798 | 18 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 799 | 18 | Defer defer = [&]() { | 800 | 18 | if (pred) { | 801 | 18 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 802 | 18 | predicates.emplace_back(pred); | 803 | 18 | } else { | 804 | | // If exception occurs during processing, do not push down | 805 | 18 | *pdt = PushDownType::UNACCEPTABLE; | 806 | 18 | } | 807 | 18 | }; | 808 | | | 809 | 18 | if (slot->get_virtual_column_expr() != nullptr) { | 810 | | // virtual column, do not push down | 811 | 0 | return Status::OK(); | 812 | 0 | } | 813 | | | 814 | 18 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 815 | 18 | DCHECK(TExprNodeType::BINARY_PRED == root->node_type()) << root->debug_string(); | 816 | 18 | DCHECK(root->get_num_children() == 2); | 817 | 18 | Field value; | 818 | 18 | *pdt = _should_push_down_binary_predicate(assert_cast<VectorizedFnCall*>(root.get()), expr_ctx, | 819 | 18 | value, {"eq", "ne", "lt", "gt", "le", "ge"}); | 820 | 18 | if (*pdt == PushDownType::UNACCEPTABLE) { | 821 | 0 | return Status::OK(); | 822 | 0 | } | 823 | 18 | const std::string& function_name = | 824 | 18 | assert_cast<VectorizedFnCall*>(root.get())->fn().name.function_name; | 825 | 18 | auto op = to_olap_filter_type(function_name); | 826 | 18 | auto is_equal_op = op == SQLFilterOp::FILTER_EQ || op == SQLFilterOp::FILTER_NE; | 827 | 18 | auto empty_range = ColumnValueRange<T>::create_empty_column_value_range( | 828 | 18 | slot->is_nullable(), range.precision(), range.scale()); | 829 | 18 | auto& temp_range = op == SQLFilterOp::FILTER_EQ ? empty_range : range; | 830 | 18 | if (value.get_type() != TYPE_NULL) { | 831 | 18 | switch (op) { | 832 | 3 | case SQLFilterOp::FILTER_EQ: | 833 | 3 | pred = create_comparison_predicate<PredicateType::EQ>( | 834 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 835 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 836 | 3 | ? root->get_child(0)->data_type() | 837 | 3 | : slot->type(), | 838 | 3 | value, false); | 839 | 3 | break; | 840 | 3 | case SQLFilterOp::FILTER_NE: | 841 | 3 | pred = create_comparison_predicate<PredicateType::NE>( | 842 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 843 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 844 | 3 | ? root->get_child(0)->data_type() | 845 | 3 | : slot->type(), | 846 | 3 | value, false); | 847 | 3 | break; | 848 | 3 | case SQLFilterOp::FILTER_LESS: | 849 | 3 | pred = create_comparison_predicate<PredicateType::LT>( | 850 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 851 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 852 | 3 | ? root->get_child(0)->data_type() | 853 | 3 | : slot->type(), | 854 | 3 | value, false); | 855 | 3 | break; | 856 | 3 | case SQLFilterOp::FILTER_LARGER: | 857 | 3 | pred = create_comparison_predicate<PredicateType::GT>( | 858 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 859 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 860 | 3 | ? root->get_child(0)->data_type() | 861 | 3 | : slot->type(), | 862 | 3 | value, false); | 863 | 3 | break; | 864 | 3 | case SQLFilterOp::FILTER_LESS_OR_EQUAL: | 865 | 3 | pred = create_comparison_predicate<PredicateType::LE>( | 866 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 867 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 868 | 3 | ? root->get_child(0)->data_type() | 869 | 3 | : slot->type(), | 870 | 3 | value, false); | 871 | 3 | break; | 872 | 3 | case SQLFilterOp::FILTER_LARGER_OR_EQUAL: | 873 | 3 | pred = create_comparison_predicate<PredicateType::GE>( | 874 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), | 875 | 3 | slot->type()->get_primitive_type() == TYPE_VARIANT | 876 | 3 | ? root->get_child(0)->data_type() | 877 | 3 | : slot->type(), | 878 | 3 | value, false); | 879 | 3 | break; | 880 | 0 | default: | 881 | 0 | throw Exception(Status::InternalError("Unsupported function name: {}", function_name)); | 882 | 18 | } | 883 | | | 884 | 18 | auto fn = op == SQLFilterOp::FILTER_EQ ? ColumnValueRange<T>::add_fixed_value_range | 885 | 18 | : op == SQLFilterOp::FILTER_NE | 886 | 15 | ? (range.is_fixed_value_range() | 887 | 3 | ? ColumnValueRange<T>::remove_fixed_value_range | 888 | 3 | : ColumnValueRange<T>::empty_function) | 889 | 15 | : ColumnValueRange<T>::add_value_range; | 890 | 18 | RETURN_IF_ERROR(_change_value_range(is_equal_op, temp_range, value, fn, function_name)); | 891 | 18 | if (op == SQLFilterOp::FILTER_EQ) { | 892 | 3 | range.intersection(temp_range); | 893 | 3 | } | 894 | 18 | } else { | 895 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 896 | 0 | _eos = true; | 897 | 0 | _scan_dependency->set_ready(); | 898 | 0 | } | 899 | | | 900 | 18 | return Status::OK(); | 901 | 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 |
902 | | |
903 | | template <PrimitiveType PrimitiveType, typename ChangeFixedValueRangeFunc> |
904 | | Status ScanLocalStateBase::_change_value_range(bool is_equal_op, |
905 | | ColumnValueRange<PrimitiveType>& temp_range, |
906 | | const Field& value, |
907 | | const ChangeFixedValueRangeFunc& func, |
908 | 122 | const std::string& fn_name) { |
909 | 122 | if constexpr (PrimitiveType == TYPE_DATE) { |
910 | 0 | auto tmp_value = value.template get<TYPE_DATE>(); |
911 | 0 | if (is_equal_op) { |
912 | 0 | if (!tmp_value.check_loss_accuracy_cast_to_date()) { |
913 | 0 | func(temp_range, to_olap_filter_type(fn_name), tmp_value); |
914 | 0 | } |
915 | 0 | } else { |
916 | 0 | if (tmp_value.check_loss_accuracy_cast_to_date()) { |
917 | 0 | if (fn_name == "lt" || fn_name == "ge") { |
918 | 0 | ++tmp_value; |
919 | 0 | } |
920 | 0 | } |
921 | 0 | func(temp_range, to_olap_filter_type(fn_name), tmp_value); |
922 | 0 | } |
923 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || |
924 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || |
925 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || |
926 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || |
927 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || |
928 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || |
929 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || |
930 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || |
931 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || |
932 | 122 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { |
933 | 122 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); |
934 | | } else { |
935 | | static_assert(always_false_v<PrimitiveType>); |
936 | | } |
937 | 122 | return Status::OK(); |
938 | 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 | 908 | 18 | const std::string& fn_name) { | 909 | | if constexpr (PrimitiveType == TYPE_DATE) { | 910 | | auto tmp_value = value.template get<TYPE_DATE>(); | 911 | | if (is_equal_op) { | 912 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 913 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 914 | | } | 915 | | } else { | 916 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 917 | | if (fn_name == "lt" || fn_name == "ge") { | 918 | | ++tmp_value; | 919 | | } | 920 | | } | 921 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 922 | | } | 923 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 924 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 925 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 926 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 927 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 928 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 929 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 930 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 931 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 932 | 18 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 933 | 18 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 934 | | } else { | 935 | | static_assert(always_false_v<PrimitiveType>); | 936 | | } | 937 | 18 | return Status::OK(); | 938 | 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 | 908 | 80 | const std::string& fn_name) { | 909 | | if constexpr (PrimitiveType == TYPE_DATE) { | 910 | | auto tmp_value = value.template get<TYPE_DATE>(); | 911 | | if (is_equal_op) { | 912 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 913 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 914 | | } | 915 | | } else { | 916 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 917 | | if (fn_name == "lt" || fn_name == "ge") { | 918 | | ++tmp_value; | 919 | | } | 920 | | } | 921 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 922 | | } | 923 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 924 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 925 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 926 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 927 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 928 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 929 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 930 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 931 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 932 | 80 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 933 | 80 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 934 | | } else { | 935 | | static_assert(always_false_v<PrimitiveType>); | 936 | | } | 937 | 80 | return Status::OK(); | 938 | 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 | 908 | 24 | const std::string& fn_name) { | 909 | | if constexpr (PrimitiveType == TYPE_DATE) { | 910 | | auto tmp_value = value.template get<TYPE_DATE>(); | 911 | | if (is_equal_op) { | 912 | | if (!tmp_value.check_loss_accuracy_cast_to_date()) { | 913 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 914 | | } | 915 | | } else { | 916 | | if (tmp_value.check_loss_accuracy_cast_to_date()) { | 917 | | if (fn_name == "lt" || fn_name == "ge") { | 918 | | ++tmp_value; | 919 | | } | 920 | | } | 921 | | func(temp_range, to_olap_filter_type(fn_name), tmp_value); | 922 | | } | 923 | | } else if constexpr ((PrimitiveType == TYPE_DECIMALV2) || (PrimitiveType == TYPE_DATETIMEV2) || | 924 | | (PrimitiveType == TYPE_TINYINT) || (PrimitiveType == TYPE_SMALLINT) || | 925 | | (PrimitiveType == TYPE_INT) || (PrimitiveType == TYPE_BIGINT) || | 926 | | (PrimitiveType == TYPE_LARGEINT) || (PrimitiveType == TYPE_FLOAT) || | 927 | | (PrimitiveType == TYPE_DOUBLE) || (PrimitiveType == TYPE_IPV4) || | 928 | | (PrimitiveType == TYPE_IPV6) || (PrimitiveType == TYPE_DECIMAL32) || | 929 | | (PrimitiveType == TYPE_DECIMAL64) || (PrimitiveType == TYPE_DECIMAL128I) || | 930 | | (PrimitiveType == TYPE_DECIMAL256) || (PrimitiveType == TYPE_BOOLEAN) || | 931 | | (PrimitiveType == TYPE_DATEV2) || (PrimitiveType == TYPE_TIMESTAMPTZ) || | 932 | 24 | (PrimitiveType == TYPE_DATETIME) || is_string_type(PrimitiveType)) { | 933 | 24 | func(temp_range, to_olap_filter_type(fn_name), value.template get<PrimitiveType>()); | 934 | | } else { | 935 | | static_assert(always_false_v<PrimitiveType>); | 936 | | } | 937 | 24 | return Status::OK(); | 938 | 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 |
939 | | |
940 | | template <PrimitiveType T> |
941 | | Status ScanLocalStateBase::_normalize_is_null_predicate( |
942 | | VExprContext* expr_ctx, const VExprSPtr& root, SlotDescriptor* slot, |
943 | | std::vector<std::shared_ptr<ColumnPredicate>>& predicates, ColumnValueRange<T>& range, |
944 | 4 | PushDownType* pdt) { |
945 | 4 | std::shared_ptr<ColumnPredicate> pred = nullptr; |
946 | 4 | Defer defer = [&]() { |
947 | 4 | if (pred) { |
948 | 4 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); |
949 | 4 | predicates.emplace_back(pred); |
950 | 4 | } else { |
951 | | // If exception occurs during processing, do not push down |
952 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
953 | 0 | } |
954 | 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 | 946 | 2 | Defer defer = [&]() { | 947 | 2 | if (pred) { | 948 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 2 | predicates.emplace_back(pred); | 950 | 2 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 0 | } | 954 | 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 | 946 | 1 | Defer defer = [&]() { | 947 | 1 | if (pred) { | 948 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 1 | predicates.emplace_back(pred); | 950 | 1 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 0 | } | 954 | 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 | 946 | 1 | Defer defer = [&]() { | 947 | 1 | if (pred) { | 948 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 1 | predicates.emplace_back(pred); | 950 | 1 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 0 | } | 954 | 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 |
955 | 4 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); |
956 | 4 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); |
957 | 4 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { |
958 | 4 | *pdt = _should_push_down_is_null_predicate(fn_call); |
959 | 4 | } else { |
960 | 0 | *pdt = PushDownType::UNACCEPTABLE; |
961 | 0 | } |
962 | | |
963 | 4 | if (*pdt == PushDownType::UNACCEPTABLE) { |
964 | 0 | return Status::OK(); |
965 | 0 | } |
966 | | |
967 | 4 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); |
968 | 4 | if (fn_call->fn().name.function_name == "is_null_pred") { |
969 | 1 | pred = NullPredicate::create_shared( |
970 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, |
971 | 1 | T); |
972 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( |
973 | 1 | slot->is_nullable(), range.precision(), range.scale()); |
974 | 1 | temp_range.set_contain_null(true); |
975 | 1 | range.intersection(temp_range); |
976 | 3 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { |
977 | 3 | pred = NullPredicate::create_shared( |
978 | 3 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, |
979 | 3 | T); |
980 | 3 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( |
981 | 3 | slot->is_nullable(), range.precision(), range.scale()); |
982 | 3 | temp_range.set_contain_null(false); |
983 | 3 | range.intersection(temp_range); |
984 | 3 | } |
985 | 4 | return Status::OK(); |
986 | 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 | 944 | 2 | PushDownType* pdt) { | 945 | 2 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 946 | 2 | Defer defer = [&]() { | 947 | 2 | if (pred) { | 948 | 2 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 2 | predicates.emplace_back(pred); | 950 | 2 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 2 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 2 | } | 954 | 2 | }; | 955 | 2 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 956 | 2 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 957 | 2 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 958 | 2 | *pdt = _should_push_down_is_null_predicate(fn_call); | 959 | 2 | } else { | 960 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 961 | 0 | } | 962 | | | 963 | 2 | if (*pdt == PushDownType::UNACCEPTABLE) { | 964 | 0 | return Status::OK(); | 965 | 0 | } | 966 | | | 967 | 2 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 968 | 2 | if (fn_call->fn().name.function_name == "is_null_pred") { | 969 | 1 | pred = NullPredicate::create_shared( | 970 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 971 | 1 | T); | 972 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 973 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 974 | 1 | temp_range.set_contain_null(true); | 975 | 1 | range.intersection(temp_range); | 976 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 977 | 1 | pred = NullPredicate::create_shared( | 978 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 979 | 1 | T); | 980 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 981 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 982 | 1 | temp_range.set_contain_null(false); | 983 | 1 | range.intersection(temp_range); | 984 | 1 | } | 985 | 2 | return Status::OK(); | 986 | 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 | 944 | 1 | PushDownType* pdt) { | 945 | 1 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 946 | 1 | Defer defer = [&]() { | 947 | 1 | if (pred) { | 948 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 1 | predicates.emplace_back(pred); | 950 | 1 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 1 | } | 954 | 1 | }; | 955 | 1 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 956 | 1 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 957 | 1 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 958 | 1 | *pdt = _should_push_down_is_null_predicate(fn_call); | 959 | 1 | } else { | 960 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 961 | 0 | } | 962 | | | 963 | 1 | if (*pdt == PushDownType::UNACCEPTABLE) { | 964 | 0 | return Status::OK(); | 965 | 0 | } | 966 | | | 967 | 1 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 968 | 1 | if (fn_call->fn().name.function_name == "is_null_pred") { | 969 | 0 | pred = NullPredicate::create_shared( | 970 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 971 | 0 | T); | 972 | 0 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 973 | 0 | slot->is_nullable(), range.precision(), range.scale()); | 974 | 0 | temp_range.set_contain_null(true); | 975 | 0 | range.intersection(temp_range); | 976 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 977 | 1 | pred = NullPredicate::create_shared( | 978 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 979 | 1 | T); | 980 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 981 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 982 | 1 | temp_range.set_contain_null(false); | 983 | 1 | range.intersection(temp_range); | 984 | 1 | } | 985 | 1 | return Status::OK(); | 986 | 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 | 944 | 1 | PushDownType* pdt) { | 945 | 1 | std::shared_ptr<ColumnPredicate> pred = nullptr; | 946 | 1 | Defer defer = [&]() { | 947 | 1 | if (pred) { | 948 | 1 | DCHECK(*pdt != PushDownType::UNACCEPTABLE) << root->debug_string(); | 949 | 1 | predicates.emplace_back(pred); | 950 | 1 | } else { | 951 | | // If exception occurs during processing, do not push down | 952 | 1 | *pdt = PushDownType::UNACCEPTABLE; | 953 | 1 | } | 954 | 1 | }; | 955 | 1 | DCHECK(!root->is_rf_wrapper()) << root->debug_string(); | 956 | 1 | DCHECK(TExprNodeType::FUNCTION_CALL == root->node_type()) << root->debug_string(); | 957 | 1 | if (auto fn_call = dynamic_cast<VectorizedFnCall*>(root.get())) { | 958 | 1 | *pdt = _should_push_down_is_null_predicate(fn_call); | 959 | 1 | } else { | 960 | 0 | *pdt = PushDownType::UNACCEPTABLE; | 961 | 0 | } | 962 | | | 963 | 1 | if (*pdt == PushDownType::UNACCEPTABLE) { | 964 | 0 | return Status::OK(); | 965 | 0 | } | 966 | | | 967 | 1 | auto fn_call = assert_cast<VectorizedFnCall*>(root.get()); | 968 | 1 | if (fn_call->fn().name.function_name == "is_null_pred") { | 969 | 0 | pred = NullPredicate::create_shared( | 970 | 0 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), true, | 971 | 0 | T); | 972 | 0 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 973 | 0 | slot->is_nullable(), range.precision(), range.scale()); | 974 | 0 | temp_range.set_contain_null(true); | 975 | 0 | range.intersection(temp_range); | 976 | 1 | } else if (fn_call->fn().name.function_name == "is_not_null_pred") { | 977 | 1 | pred = NullPredicate::create_shared( | 978 | 1 | _parent->intermediate_row_desc().get_column_id(slot->id()), slot->col_name(), false, | 979 | 1 | T); | 980 | 1 | auto temp_range = ColumnValueRange<T>::create_empty_column_value_range( | 981 | 1 | slot->is_nullable(), range.precision(), range.scale()); | 982 | 1 | temp_range.set_contain_null(false); | 983 | 1 | range.intersection(temp_range); | 984 | 1 | } | 985 | 1 | return Status::OK(); | 986 | 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 |
987 | | |
988 | | template <typename Derived> |
989 | 0 | Status ScanLocalState<Derived>::_prepare_scanners() { |
990 | 0 | std::list<ScannerSPtr> scanners; |
991 | 0 | RETURN_IF_ERROR(_init_scanners(&scanners)); |
992 | | // Init scanner wrapper |
993 | 0 | for (auto it = scanners.begin(); it != scanners.end(); ++it) { |
994 | 0 | _scanners.emplace_back(std::make_shared<ScannerDelegate>(*it)); |
995 | 0 | } |
996 | 0 | if (scanners.empty()) { |
997 | 0 | _eos = true; |
998 | 0 | _scan_dependency->set_always_ready(); |
999 | 0 | } else { |
1000 | 0 | COUNTER_SET(_num_scanners, static_cast<int64_t>(scanners.size())); |
1001 | 0 | RETURN_IF_ERROR(_start_scanners(_scanners)); |
1002 | 0 | } |
1003 | 0 | return Status::OK(); |
1004 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17_prepare_scannersEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE17_prepare_scannersEv |
1005 | | |
1006 | | template <typename Derived> |
1007 | | Status ScanLocalState<Derived>::_start_scanners( |
1008 | 0 | const std::list<std::shared_ptr<ScannerDelegate>>& scanners) { |
1009 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1010 | 0 | _scanner_ctx.store(ScannerContext::create_shared(state(), this, p._output_tuple_desc, |
1011 | 0 | p.output_row_descriptor(), scanners, p.limit(), |
1012 | 0 | _scan_dependency |
1013 | 0 | #ifdef BE_TEST |
1014 | 0 | , |
1015 | 0 | max_scanners_concurrency(state()) |
1016 | 0 | #endif |
1017 | 0 | )); |
1018 | 0 | return Status::OK(); |
1019 | 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_16EsScanLocalStateEE15_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 |
1020 | | |
1021 | | template <typename Derived> |
1022 | 0 | const TupleDescriptor* ScanLocalState<Derived>::input_tuple_desc() const { |
1023 | 0 | return _parent->cast<typename Derived::Parent>()._input_tuple_desc; |
1024 | 0 | } Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_16EsScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE16input_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE16input_tuple_descEv |
1025 | | template <typename Derived> |
1026 | 12 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { |
1027 | 12 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; |
1028 | 12 | } _ZNK5doris14ScanLocalStateINS_18OlapScanLocalStateEE17output_tuple_descEv Line | Count | Source | 1026 | 11 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { | 1027 | 11 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; | 1028 | 11 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17output_tuple_descEv _ZNK5doris14ScanLocalStateINS_18FileScanLocalStateEE17output_tuple_descEv Line | Count | Source | 1026 | 1 | const TupleDescriptor* ScanLocalState<Derived>::output_tuple_desc() const { | 1027 | 1 | return _parent->cast<typename Derived::Parent>()._output_tuple_desc; | 1028 | 1 | } |
Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_16EsScanLocalStateEE17output_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MetaScanLocalStateEE17output_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17output_tuple_descEv Unexecuted instantiation: _ZNK5doris14ScanLocalStateINS_18MockScanLocalStateEE17output_tuple_descEv |
1029 | | |
1030 | | template <typename Derived> |
1031 | 0 | TPushAggOp::type ScanLocalState<Derived>::get_push_down_agg_type() { |
1032 | 0 | return _parent->cast<typename Derived::Parent>()._push_down_agg_type; |
1033 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE22get_push_down_agg_typeEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE22get_push_down_agg_typeEv |
1034 | | |
1035 | | template <typename Derived> |
1036 | 0 | int64_t ScanLocalState<Derived>::limit_per_scanner() { |
1037 | 0 | return _parent->cast<typename Derived::Parent>()._limit_per_scanner; |
1038 | 0 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE17limit_per_scannerEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE17limit_per_scannerEv |
1039 | | |
1040 | | template <typename Derived> |
1041 | 2 | Status ScanLocalState<Derived>::_init_profile() { |
1042 | | // 1. counters for scan node |
1043 | 2 | _rows_read_counter = ADD_COUNTER(custom_profile(), "RowsRead", TUnit::UNIT); |
1044 | 2 | _num_scanners = ADD_COUNTER(custom_profile(), "NumScanners", TUnit::UNIT); |
1045 | | //custom_profile()->AddHighWaterMarkCounter("PeakMemoryUsage", TUnit::BYTES); |
1046 | | |
1047 | | // 2. counters for scanners |
1048 | 2 | _scanner_profile.reset(new RuntimeProfile("Scanner")); |
1049 | 2 | custom_profile()->add_child(_scanner_profile.get(), true, nullptr); |
1050 | | |
1051 | 2 | _newly_create_free_blocks_num = |
1052 | 2 | ADD_COUNTER(_scanner_profile, "NewlyCreateFreeBlocksNum", TUnit::UNIT); |
1053 | 2 | _scan_timer = ADD_TIMER(_scanner_profile, "ScannerGetBlockTime"); |
1054 | 2 | _scan_cpu_timer = ADD_TIMER(_scanner_profile, "ScannerCpuTime"); |
1055 | 2 | _filter_timer = ADD_TIMER(_scanner_profile, "ScannerFilterTime"); |
1056 | | |
1057 | | // time of scan thread to wait for worker thread of the thread pool |
1058 | 2 | _scanner_wait_worker_timer = ADD_TIMER(custom_profile(), "ScannerWorkerWaitTime"); |
1059 | | |
1060 | 2 | _max_scan_concurrency = ADD_COUNTER(custom_profile(), "MaxScanConcurrency", TUnit::UNIT); |
1061 | 2 | _min_scan_concurrency = ADD_COUNTER(custom_profile(), "MinScanConcurrency", TUnit::UNIT); |
1062 | | |
1063 | 2 | _peak_running_scanner = |
1064 | 2 | _scanner_profile->AddHighWaterMarkCounter("RunningScanner", TUnit::UNIT); |
1065 | | |
1066 | 2 | _condition_cache_hit_counter = ADD_COUNTER(_scanner_profile, "ConditionCacheHit", TUnit::UNIT); |
1067 | 2 | _condition_cache_filtered_rows_counter = |
1068 | 2 | ADD_COUNTER(_scanner_profile, "ConditionCacheFilteredRows", TUnit::UNIT); |
1069 | | |
1070 | | // Rows read from storage. |
1071 | | // Include the rows read from doris page cache. |
1072 | 2 | _scan_rows = ADD_COUNTER_WITH_LEVEL(custom_profile(), "ScanRows", TUnit::UNIT, 1); |
1073 | | // Size of data that read from storage. |
1074 | | // Does not include rows that are cached by doris page cache. |
1075 | 2 | _scan_bytes = ADD_COUNTER_WITH_LEVEL(custom_profile(), "ScanBytes", TUnit::BYTES, 1); |
1076 | 2 | return Status::OK(); |
1077 | 2 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE13_init_profileEv _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE13_init_profileEv Line | Count | Source | 1041 | 2 | Status ScanLocalState<Derived>::_init_profile() { | 1042 | | // 1. counters for scan node | 1043 | 2 | _rows_read_counter = ADD_COUNTER(custom_profile(), "RowsRead", TUnit::UNIT); | 1044 | 2 | _num_scanners = ADD_COUNTER(custom_profile(), "NumScanners", TUnit::UNIT); | 1045 | | //custom_profile()->AddHighWaterMarkCounter("PeakMemoryUsage", TUnit::BYTES); | 1046 | | | 1047 | | // 2. counters for scanners | 1048 | 2 | _scanner_profile.reset(new RuntimeProfile("Scanner")); | 1049 | 2 | custom_profile()->add_child(_scanner_profile.get(), true, nullptr); | 1050 | | | 1051 | 2 | _newly_create_free_blocks_num = | 1052 | 2 | ADD_COUNTER(_scanner_profile, "NewlyCreateFreeBlocksNum", TUnit::UNIT); | 1053 | 2 | _scan_timer = ADD_TIMER(_scanner_profile, "ScannerGetBlockTime"); | 1054 | 2 | _scan_cpu_timer = ADD_TIMER(_scanner_profile, "ScannerCpuTime"); | 1055 | 2 | _filter_timer = ADD_TIMER(_scanner_profile, "ScannerFilterTime"); | 1056 | | | 1057 | | // time of scan thread to wait for worker thread of the thread pool | 1058 | 2 | _scanner_wait_worker_timer = ADD_TIMER(custom_profile(), "ScannerWorkerWaitTime"); | 1059 | | | 1060 | 2 | _max_scan_concurrency = ADD_COUNTER(custom_profile(), "MaxScanConcurrency", TUnit::UNIT); | 1061 | 2 | _min_scan_concurrency = ADD_COUNTER(custom_profile(), "MinScanConcurrency", TUnit::UNIT); | 1062 | | | 1063 | 2 | _peak_running_scanner = | 1064 | 2 | _scanner_profile->AddHighWaterMarkCounter("RunningScanner", TUnit::UNIT); | 1065 | | | 1066 | 2 | _condition_cache_hit_counter = ADD_COUNTER(_scanner_profile, "ConditionCacheHit", TUnit::UNIT); | 1067 | 2 | _condition_cache_filtered_rows_counter = | 1068 | 2 | ADD_COUNTER(_scanner_profile, "ConditionCacheFilteredRows", TUnit::UNIT); | 1069 | | | 1070 | | // Rows read from storage. | 1071 | | // Include the rows read from doris page cache. | 1072 | 2 | _scan_rows = ADD_COUNTER_WITH_LEVEL(custom_profile(), "ScanRows", TUnit::UNIT, 1); | 1073 | | // Size of data that read from storage. | 1074 | | // Does not include rows that are cached by doris page cache. | 1075 | 2 | _scan_bytes = ADD_COUNTER_WITH_LEVEL(custom_profile(), "ScanBytes", TUnit::BYTES, 1); | 1076 | 2 | return Status::OK(); | 1077 | 2 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE13_init_profileEv Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE13_init_profileEv |
1078 | | |
1079 | | template <typename Derived> |
1080 | 0 | Status ScanLocalState<Derived>::_get_topn_filters(RuntimeState* state) { |
1081 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1082 | 0 | std::stringstream result; |
1083 | 0 | std::copy(p._topn_filter_source_node_ids.begin(), p._topn_filter_source_node_ids.end(), |
1084 | 0 | std::ostream_iterator<int>(result, ",")); |
1085 | 0 | custom_profile()->add_info_string("TopNFilterSourceNodeIds", result.str()); |
1086 | |
|
1087 | 0 | for (auto id : get_topn_filter_source_node_ids(state, false)) { |
1088 | 0 | const auto& pred = state->get_query_ctx()->get_runtime_predicate(id); |
1089 | 0 | VExprSPtr topn_pred; |
1090 | 0 | RETURN_IF_ERROR(VTopNPred::create_vtopn_pred(pred.get_texpr(p.node_id()), id, topn_pred)); |
1091 | | |
1092 | 0 | VExprContextSPtr conjunct = VExprContext::create_shared(topn_pred); |
1093 | 0 | RETURN_IF_ERROR(conjunct->prepare( |
1094 | 0 | state, _parent->cast<typename Derived::Parent>().row_descriptor())); |
1095 | 0 | RETURN_IF_ERROR(conjunct->open(state)); |
1096 | 0 | _conjuncts.emplace_back(conjunct); |
1097 | 0 | } |
1098 | 0 | for (auto id : get_topn_filter_source_node_ids(state, true)) { |
1099 | 0 | const auto& pred = state->get_query_ctx()->get_runtime_predicate(id); |
1100 | 0 | VExprSPtr topn_pred; |
1101 | 0 | RETURN_IF_ERROR(VTopNPred::create_vtopn_pred(pred.get_texpr(p.node_id()), id, topn_pred)); |
1102 | | |
1103 | 0 | VExprContextSPtr conjunct = VExprContext::create_shared(topn_pred); |
1104 | 0 | RETURN_IF_ERROR(conjunct->prepare( |
1105 | 0 | state, _parent->cast<typename Derived::Parent>().row_descriptor())); |
1106 | 0 | RETURN_IF_ERROR(conjunct->open(state)); |
1107 | 0 | _conjuncts.emplace_back(conjunct); |
1108 | 0 | } |
1109 | 0 | return Status::OK(); |
1110 | 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_16EsScanLocalStateEE17_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 |
1111 | | |
1112 | | template <typename Derived> |
1113 | | void ScanLocalState<Derived>::_filter_and_collect_cast_type_for_variant( |
1114 | | const VExpr* expr, |
1115 | 0 | std::unordered_map<std::string, std::vector<DataTypePtr>>& colname_to_cast_types) { |
1116 | 0 | auto& p = _parent->cast<typename Derived::Parent>(); |
1117 | 0 | const auto* cast_expr = dynamic_cast<const VCastExpr*>(expr); |
1118 | 0 | if (cast_expr != nullptr) { |
1119 | 0 | const auto* src_slot = |
1120 | 0 | cast_expr->get_child(0)->node_type() == TExprNodeType::SLOT_REF |
1121 | 0 | ? dynamic_cast<const VSlotRef*>(cast_expr->get_child(0).get()) |
1122 | 0 | : nullptr; |
1123 | 0 | if (src_slot == nullptr) { |
1124 | 0 | return; |
1125 | 0 | } |
1126 | 0 | std::vector<SlotDescriptor*> slots = output_tuple_desc()->slots(); |
1127 | 0 | SlotDescriptor* src_slot_desc = p._slot_id_to_slot_desc[src_slot->slot_id()]; |
1128 | 0 | auto type_desc = cast_expr->get_target_type(); |
1129 | 0 | if (src_slot_desc->type()->get_primitive_type() == PrimitiveType::TYPE_VARIANT) { |
1130 | 0 | colname_to_cast_types[src_slot_desc->col_name()].push_back(type_desc); |
1131 | 0 | } |
1132 | 0 | } |
1133 | 0 | for (const auto& child : expr->children()) { |
1134 | 0 | _filter_and_collect_cast_type_for_variant(child.get(), colname_to_cast_types); |
1135 | 0 | } |
1136 | 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_16EsScanLocalStateEE41_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 |
1137 | | |
1138 | | template <typename Derived> |
1139 | 0 | void ScanLocalState<Derived>::get_cast_types_for_variants() { |
1140 | 0 | std::unordered_map<std::string, std::vector<DataTypePtr>> colname_to_cast_types; |
1141 | 0 | for (auto it = _conjuncts.begin(); it != _conjuncts.end();) { |
1142 | 0 | auto& conjunct = *it; |
1143 | 0 | if (conjunct->root()) { |
1144 | 0 | _filter_and_collect_cast_type_for_variant(conjunct->root().get(), |
1145 | 0 | colname_to_cast_types); |
1146 | 0 | } |
1147 | 0 | ++it; |
1148 | 0 | } |
1149 | | // cast to one certain type for variant could utilize fully predicates performance |
1150 | | // when storage layer type equals to cast type |
1151 | 0 | for (const auto& [slotid, types] : colname_to_cast_types) { |
1152 | 0 | if (types.size() == 1) { |
1153 | 0 | _cast_types_for_variants[slotid] = types[0]; |
1154 | 0 | } |
1155 | 0 | } |
1156 | 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_16EsScanLocalStateEE27get_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 |
1157 | | |
1158 | | template <typename LocalStateType> |
1159 | | ScanOperatorX<LocalStateType>::ScanOperatorX(ObjectPool* pool, const TPlanNode& tnode, |
1160 | | int operator_id, const DescriptorTbl& descs, |
1161 | | int parallel_tasks) |
1162 | 15 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), |
1163 | 15 | _runtime_filter_descs(tnode.runtime_filters), |
1164 | 15 | _parallel_tasks(parallel_tasks) { |
1165 | 15 | if (tnode.__isset.push_down_count) { |
1166 | 0 | _push_down_count = tnode.push_down_count; |
1167 | 0 | } |
1168 | 15 | } _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Line | Count | Source | 1162 | 13 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), | 1163 | 13 | _runtime_filter_descs(tnode.runtime_filters), | 1164 | 13 | _parallel_tasks(parallel_tasks) { | 1165 | 13 | if (tnode.__isset.push_down_count) { | 1166 | 0 | _push_down_count = tnode.push_down_count; | 1167 | 0 | } | 1168 | 13 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Line | Count | Source | 1162 | 2 | : OperatorX<LocalStateType>(pool, tnode, operator_id, descs), | 1163 | 2 | _runtime_filter_descs(tnode.runtime_filters), | 1164 | 2 | _parallel_tasks(parallel_tasks) { | 1165 | 2 | if (tnode.__isset.push_down_count) { | 1166 | 0 | _push_down_count = tnode.push_down_count; | 1167 | 0 | } | 1168 | 2 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_16EsScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEEC2EPNS_10ObjectPoolERKNS_9TPlanNodeEiRKNS_13DescriptorTblEi |
1169 | | |
1170 | | template <typename LocalStateType> |
1171 | 6 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { |
1172 | 6 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); |
1173 | | |
1174 | 6 | const TQueryOptions& query_options = state->query_options(); |
1175 | 6 | if (query_options.__isset.max_scan_key_num) { |
1176 | 0 | _max_scan_key_num = query_options.max_scan_key_num; |
1177 | 0 | } |
1178 | 6 | if (query_options.__isset.max_pushdown_conditions_per_column) { |
1179 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; |
1180 | 0 | } |
1181 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated |
1182 | | // Introduced a new field : tnode.push_down_agg_type_opt |
1183 | | // |
1184 | | // make it compatible here |
1185 | 6 | if (tnode.__isset.push_down_agg_type_opt) { |
1186 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; |
1187 | 6 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { |
1188 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; |
1189 | 6 | } else { |
1190 | 6 | _push_down_agg_type = TPushAggOp::type::NONE; |
1191 | 6 | } |
1192 | | |
1193 | 6 | if (tnode.__isset.topn_filter_source_node_ids) { |
1194 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; |
1195 | 0 | } |
1196 | | |
1197 | | // Which means the request could be fullfilled in a single segment iterator request. |
1198 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, |
1199 | | // now add some check for unique_table let running only one instance for select limit n. |
1200 | 6 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { |
1201 | 5 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); |
1202 | 5 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || |
1203 | 5 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && |
1204 | 4 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { |
1205 | 4 | if (tnode.limit > 0 && |
1206 | 4 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { |
1207 | 1 | _should_run_serial = true; |
1208 | 1 | } |
1209 | 4 | } |
1210 | 5 | } |
1211 | | |
1212 | 6 | return Status::OK(); |
1213 | 6 | } _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Line | Count | Source | 1171 | 4 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { | 1172 | 4 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); | 1173 | | | 1174 | 4 | const TQueryOptions& query_options = state->query_options(); | 1175 | 4 | if (query_options.__isset.max_scan_key_num) { | 1176 | 0 | _max_scan_key_num = query_options.max_scan_key_num; | 1177 | 0 | } | 1178 | 4 | if (query_options.__isset.max_pushdown_conditions_per_column) { | 1179 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; | 1180 | 0 | } | 1181 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated | 1182 | | // Introduced a new field : tnode.push_down_agg_type_opt | 1183 | | // | 1184 | | // make it compatible here | 1185 | 4 | if (tnode.__isset.push_down_agg_type_opt) { | 1186 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; | 1187 | 4 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { | 1188 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; | 1189 | 4 | } else { | 1190 | 4 | _push_down_agg_type = TPushAggOp::type::NONE; | 1191 | 4 | } | 1192 | | | 1193 | 4 | if (tnode.__isset.topn_filter_source_node_ids) { | 1194 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; | 1195 | 0 | } | 1196 | | | 1197 | | // Which means the request could be fullfilled in a single segment iterator request. | 1198 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, | 1199 | | // now add some check for unique_table let running only one instance for select limit n. | 1200 | 4 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { | 1201 | 3 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); | 1202 | 3 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || | 1203 | 3 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && | 1204 | 2 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { | 1205 | 2 | if (tnode.limit > 0 && | 1206 | 2 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { | 1207 | 1 | _should_run_serial = true; | 1208 | 1 | } | 1209 | 2 | } | 1210 | 3 | } | 1211 | | | 1212 | 4 | return Status::OK(); | 1213 | 4 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Line | Count | Source | 1171 | 2 | Status ScanOperatorX<LocalStateType>::init(const TPlanNode& tnode, RuntimeState* state) { | 1172 | 2 | RETURN_IF_ERROR(OperatorX<LocalStateType>::init(tnode, state)); | 1173 | | | 1174 | 2 | const TQueryOptions& query_options = state->query_options(); | 1175 | 2 | if (query_options.__isset.max_scan_key_num) { | 1176 | 0 | _max_scan_key_num = query_options.max_scan_key_num; | 1177 | 0 | } | 1178 | 2 | if (query_options.__isset.max_pushdown_conditions_per_column) { | 1179 | 0 | _max_pushdown_conditions_per_column = query_options.max_pushdown_conditions_per_column; | 1180 | 0 | } | 1181 | | // tnode.olap_scan_node.push_down_agg_type_opt field is deprecated | 1182 | | // Introduced a new field : tnode.push_down_agg_type_opt | 1183 | | // | 1184 | | // make it compatible here | 1185 | 2 | if (tnode.__isset.push_down_agg_type_opt) { | 1186 | 0 | _push_down_agg_type = tnode.push_down_agg_type_opt; | 1187 | 2 | } else if (tnode.olap_scan_node.__isset.push_down_agg_type_opt) { | 1188 | 0 | _push_down_agg_type = tnode.olap_scan_node.push_down_agg_type_opt; | 1189 | 2 | } else { | 1190 | 2 | _push_down_agg_type = TPushAggOp::type::NONE; | 1191 | 2 | } | 1192 | | | 1193 | 2 | if (tnode.__isset.topn_filter_source_node_ids) { | 1194 | 0 | _topn_filter_source_node_ids = tnode.topn_filter_source_node_ids; | 1195 | 0 | } | 1196 | | | 1197 | | // Which means the request could be fullfilled in a single segment iterator request. | 1198 | | // the unique_table has a condition of delete_sign = 0 awalys, so it's not have plan for one instance to scan table, | 1199 | | // now add some check for unique_table let running only one instance for select limit n. | 1200 | 2 | if (query_options.enable_adaptive_pipeline_task_serial_read_on_limit) { | 1201 | 2 | DCHECK(query_options.__isset.adaptive_pipeline_task_serial_read_on_limit); | 1202 | 2 | if (!tnode.__isset.conjuncts || tnode.conjuncts.empty() || | 1203 | 2 | (tnode.conjuncts.size() == 1 && tnode.__isset.olap_scan_node && | 1204 | 2 | tnode.olap_scan_node.keyType == TKeysType::UNIQUE_KEYS)) { | 1205 | 2 | if (tnode.limit > 0 && | 1206 | 2 | tnode.limit <= query_options.adaptive_pipeline_task_serial_read_on_limit) { | 1207 | 0 | _should_run_serial = true; | 1208 | 0 | } | 1209 | 2 | } | 1210 | 2 | } | 1211 | | | 1212 | 2 | return Status::OK(); | 1213 | 2 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_16EsScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE4initERKNS_9TPlanNodeEPNS_12RuntimeStateE |
1214 | | |
1215 | | template <typename LocalStateType> |
1216 | 2 | Status ScanOperatorX<LocalStateType>::prepare(RuntimeState* state) { |
1217 | 2 | _input_tuple_desc = state->desc_tbl().get_tuple_descriptor(_input_tuple_id); |
1218 | 2 | _output_tuple_desc = state->desc_tbl().get_tuple_descriptor(_output_tuple_id); |
1219 | 2 | RETURN_IF_ERROR(OperatorX<LocalStateType>::prepare(state)); |
1220 | | |
1221 | 2 | const auto slots = _output_tuple_desc->slots(); |
1222 | 6 | for (auto* slot : slots) { |
1223 | 6 | _colname_to_slot_id[slot->col_name()] = slot->id(); |
1224 | 6 | _slot_id_to_slot_desc[slot->id()] = slot; |
1225 | 6 | } |
1226 | 2 | for (auto id : _topn_filter_source_node_ids) { |
1227 | 0 | if (!state->get_query_ctx()->has_runtime_predicate(id)) { |
1228 | | // compatible with older versions fe |
1229 | 0 | continue; |
1230 | 0 | } |
1231 | | |
1232 | 0 | int cid = -1; |
1233 | 0 | if (state->get_query_ctx()->get_runtime_predicate(id).target_is_slot(node_id())) { |
1234 | 0 | auto s = _slot_id_to_slot_desc[state->get_query_ctx() |
1235 | 0 | ->get_runtime_predicate(id) |
1236 | 0 | .get_texpr(node_id()) |
1237 | 0 | .nodes[0] |
1238 | 0 | .slot_ref.slot_id]; |
1239 | 0 | DCHECK(s != nullptr); |
1240 | 0 | if (remove_nullable(s->type())->get_primitive_type() == TYPE_VARBINARY) { |
1241 | 0 | continue; |
1242 | 0 | } |
1243 | 0 | auto col_name = s->col_name(); |
1244 | 0 | cid = get_column_id(col_name); |
1245 | 0 | } |
1246 | 0 | RETURN_IF_ERROR(state->get_query_ctx()->get_runtime_predicate(id).init_target( |
1247 | 0 | node_id(), _slot_id_to_slot_desc, cid)); |
1248 | 0 | } |
1249 | | |
1250 | 2 | RETURN_IF_CANCELLED(state); |
1251 | 2 | return Status::OK(); |
1252 | 2 | } Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE7prepareEPNS_12RuntimeStateE _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE7prepareEPNS_12RuntimeStateE Line | Count | Source | 1216 | 2 | Status ScanOperatorX<LocalStateType>::prepare(RuntimeState* state) { | 1217 | 2 | _input_tuple_desc = state->desc_tbl().get_tuple_descriptor(_input_tuple_id); | 1218 | 2 | _output_tuple_desc = state->desc_tbl().get_tuple_descriptor(_output_tuple_id); | 1219 | 2 | RETURN_IF_ERROR(OperatorX<LocalStateType>::prepare(state)); | 1220 | | | 1221 | 2 | const auto slots = _output_tuple_desc->slots(); | 1222 | 6 | for (auto* slot : slots) { | 1223 | 6 | _colname_to_slot_id[slot->col_name()] = slot->id(); | 1224 | 6 | _slot_id_to_slot_desc[slot->id()] = slot; | 1225 | 6 | } | 1226 | 2 | for (auto id : _topn_filter_source_node_ids) { | 1227 | 0 | if (!state->get_query_ctx()->has_runtime_predicate(id)) { | 1228 | | // compatible with older versions fe | 1229 | 0 | continue; | 1230 | 0 | } | 1231 | | | 1232 | 0 | int cid = -1; | 1233 | 0 | if (state->get_query_ctx()->get_runtime_predicate(id).target_is_slot(node_id())) { | 1234 | 0 | auto s = _slot_id_to_slot_desc[state->get_query_ctx() | 1235 | 0 | ->get_runtime_predicate(id) | 1236 | 0 | .get_texpr(node_id()) | 1237 | 0 | .nodes[0] | 1238 | 0 | .slot_ref.slot_id]; | 1239 | 0 | DCHECK(s != nullptr); | 1240 | 0 | if (remove_nullable(s->type())->get_primitive_type() == TYPE_VARBINARY) { | 1241 | 0 | continue; | 1242 | 0 | } | 1243 | 0 | auto col_name = s->col_name(); | 1244 | 0 | cid = get_column_id(col_name); | 1245 | 0 | } | 1246 | 0 | RETURN_IF_ERROR(state->get_query_ctx()->get_runtime_predicate(id).init_target( | 1247 | 0 | node_id(), _slot_id_to_slot_desc, cid)); | 1248 | 0 | } | 1249 | | | 1250 | 2 | RETURN_IF_CANCELLED(state); | 1251 | 2 | return Status::OK(); | 1252 | 2 | } |
Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_16EsScanLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE7prepareEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE7prepareEPNS_12RuntimeStateE |
1253 | | |
1254 | | template <typename Derived> |
1255 | 2 | Status ScanLocalState<Derived>::close(RuntimeState* state) { |
1256 | 2 | if (_closed) { |
1257 | 0 | return Status::OK(); |
1258 | 0 | } |
1259 | 2 | COUNTER_UPDATE(exec_time_counter(), _scan_dependency->watcher_elapse_time()); |
1260 | 2 | int64_t rf_time = 0; |
1261 | 2 | for (auto& dep : _filter_dependencies) { |
1262 | 0 | rf_time += dep->watcher_elapse_time(); |
1263 | 0 | } |
1264 | 2 | COUNTER_UPDATE(exec_time_counter(), rf_time); |
1265 | 2 | SCOPED_TIMER(_close_timer); |
1266 | | |
1267 | 2 | SCOPED_TIMER(exec_time_counter()); |
1268 | 2 | if (auto ctx = _scanner_ctx.load()) { |
1269 | 0 | ctx->stop_scanners(state); |
1270 | | // _scanner_ctx may be accessed in debug_string concurrently |
1271 | | // so use atomic shared ptr to avoid use after free |
1272 | 0 | _scanner_ctx.store(nullptr); |
1273 | 0 | } |
1274 | 2 | std::list<std::shared_ptr<ScannerDelegate>> {}.swap(_scanners); |
1275 | 2 | COUNTER_SET(_wait_for_dependency_timer, _scan_dependency->watcher_elapse_time()); |
1276 | 2 | COUNTER_SET(_wait_for_rf_timer, rf_time); |
1277 | 2 | _helper.collect_realtime_profile(custom_profile()); |
1278 | 2 | return PipelineXLocalState<>::close(state); |
1279 | 2 | } Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18OlapScanLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18JDBCScanLocalStateEE5closeEPNS_12RuntimeStateE _ZN5doris14ScanLocalStateINS_18FileScanLocalStateEE5closeEPNS_12RuntimeStateE Line | Count | Source | 1255 | 2 | Status ScanLocalState<Derived>::close(RuntimeState* state) { | 1256 | 2 | if (_closed) { | 1257 | 0 | return Status::OK(); | 1258 | 0 | } | 1259 | 2 | COUNTER_UPDATE(exec_time_counter(), _scan_dependency->watcher_elapse_time()); | 1260 | 2 | int64_t rf_time = 0; | 1261 | 2 | for (auto& dep : _filter_dependencies) { | 1262 | 0 | rf_time += dep->watcher_elapse_time(); | 1263 | 0 | } | 1264 | 2 | COUNTER_UPDATE(exec_time_counter(), rf_time); | 1265 | 2 | SCOPED_TIMER(_close_timer); | 1266 | | | 1267 | 2 | SCOPED_TIMER(exec_time_counter()); | 1268 | 2 | if (auto ctx = _scanner_ctx.load()) { | 1269 | 0 | ctx->stop_scanners(state); | 1270 | | // _scanner_ctx may be accessed in debug_string concurrently | 1271 | | // so use atomic shared ptr to avoid use after free | 1272 | 0 | _scanner_ctx.store(nullptr); | 1273 | 0 | } | 1274 | 2 | std::list<std::shared_ptr<ScannerDelegate>> {}.swap(_scanners); | 1275 | 2 | COUNTER_SET(_wait_for_dependency_timer, _scan_dependency->watcher_elapse_time()); | 1276 | 2 | COUNTER_SET(_wait_for_rf_timer, rf_time); | 1277 | 2 | _helper.collect_realtime_profile(custom_profile()); | 1278 | 2 | return PipelineXLocalState<>::close(state); | 1279 | 2 | } |
Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_16EsScanLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MetaScanLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_21GroupCommitLocalStateEE5closeEPNS_12RuntimeStateE Unexecuted instantiation: _ZN5doris14ScanLocalStateINS_18MockScanLocalStateEE5closeEPNS_12RuntimeStateE |
1280 | | |
1281 | | template <typename LocalStateType> |
1282 | 0 | Status ScanOperatorX<LocalStateType>::get_block(RuntimeState* state, Block* block, bool* eos) { |
1283 | 0 | auto& local_state = get_local_state(state); |
1284 | 0 | SCOPED_TIMER(local_state.exec_time_counter()); |
1285 | |
|
1286 | 0 | if (state->is_cancelled()) { |
1287 | 0 | if (auto ctx = local_state._scanner_ctx.load()) { |
1288 | 0 | ctx->stop_scanners(state); |
1289 | 0 | } |
1290 | 0 | return state->cancel_reason(); |
1291 | 0 | } |
1292 | | |
1293 | 0 | if (local_state._eos) { |
1294 | 0 | *eos = true; |
1295 | 0 | return Status::OK(); |
1296 | 0 | } |
1297 | | |
1298 | 0 | auto ctx = local_state._scanner_ctx.load(); |
1299 | |
|
1300 | 0 | DCHECK(ctx != nullptr); |
1301 | 0 | RETURN_IF_ERROR(ctx->get_block_from_queue(state, block, eos, 0)); |
1302 | | |
1303 | 0 | local_state.reached_limit(block, eos); |
1304 | 0 | if (*eos) { |
1305 | | // reach limit, stop the scanners. |
1306 | 0 | ctx->stop_scanners(state); |
1307 | 0 | local_state._scanner_profile->add_info_string("EOS", "True"); |
1308 | 0 | } |
1309 | |
|
1310 | 0 | return Status::OK(); |
1311 | 0 | } Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18OlapScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18JDBCScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18FileScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_16EsScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MetaScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_21GroupCommitLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb Unexecuted instantiation: _ZN5doris13ScanOperatorXINS_18MockScanLocalStateEE9get_blockEPNS_12RuntimeStateEPNS_5BlockEPb |
1312 | | |
1313 | | template <typename LocalStateType> |
1314 | 0 | size_t ScanOperatorX<LocalStateType>::get_reserve_mem_size(RuntimeState* state) { |
1315 | 0 | auto& local_state = get_local_state(state); |
1316 | 0 | auto ctx = local_state._scanner_ctx.load(); |
1317 | 0 | if (!local_state._opened || local_state._closed || !ctx) { |
1318 | 0 | return config::doris_scanner_row_bytes; |
1319 | 0 | } |
1320 | | |
1321 | 0 | if (local_state.low_memory_mode()) { |
1322 | 0 | return ctx->low_memory_mode_scan_bytes_per_scanner() * ctx->low_memory_mode_scanners(); |
1323 | 0 | } else { |
1324 | 0 | const auto peak_usage = local_state._memory_used_counter->value(); |
1325 | 0 | const auto block_usage = ctx->block_memory_usage(); |
1326 | 0 | if (peak_usage > 0) { |
1327 | | // It is only a safty check, to avoid some counter not right. |
1328 | 0 | if (peak_usage > block_usage) { |
1329 | 0 | return peak_usage - block_usage; |
1330 | 0 | } else { |
1331 | 0 | return config::doris_scanner_row_bytes; |
1332 | 0 | } |
1333 | 0 | } else { |
1334 | | // If the scan operator is first time to run, then we think it will occupy doris_scanner_row_bytes. |
1335 | | // It maybe a little smaller than actual usage. |
1336 | 0 | return config::doris_scanner_row_bytes; |
1337 | | // return local_state._scanner_ctx->max_bytes_in_queue(); |
1338 | 0 | } |
1339 | 0 | } |
1340 | 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_16EsScanLocalStateEE20get_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 |
1341 | | |
1342 | | template class ScanOperatorX<OlapScanLocalState>; |
1343 | | template class ScanLocalState<OlapScanLocalState>; |
1344 | | template class ScanOperatorX<JDBCScanLocalState>; |
1345 | | template class ScanLocalState<JDBCScanLocalState>; |
1346 | | template class ScanOperatorX<FileScanLocalState>; |
1347 | | template class ScanLocalState<FileScanLocalState>; |
1348 | | template class ScanOperatorX<EsScanLocalState>; |
1349 | | template class ScanLocalState<EsScanLocalState>; |
1350 | | template class ScanLocalState<MetaScanLocalState>; |
1351 | | template class ScanOperatorX<MetaScanLocalState>; |
1352 | | template class ScanOperatorX<GroupCommitLocalState>; |
1353 | | template class ScanLocalState<GroupCommitLocalState>; |
1354 | | |
1355 | | #ifdef BE_TEST |
1356 | | template class ScanOperatorX<MockScanLocalState>; |
1357 | | template class ScanLocalState<MockScanLocalState>; |
1358 | | #endif |
1359 | | |
1360 | | } // namespace doris |