be/src/exprs/function/array/function_array_distinct.h
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 | | // This file is copied from |
18 | | // https://github.com/ClickHouse/ClickHouse/blob/master/src/Functions/array/arrayDistinct.cpp |
19 | | // and modified by Doris |
20 | | #pragma once |
21 | | |
22 | | #include <fmt/format.h> |
23 | | #include <glog/logging.h> |
24 | | |
25 | | #include <cstring> |
26 | | #include <memory> |
27 | | #include <ostream> |
28 | | #include <utility> |
29 | | |
30 | | #include "common/status.h" |
31 | | #include "core/assert_cast.h" |
32 | | #include "core/block/block.h" |
33 | | #include "core/block/column_numbers.h" |
34 | | #include "core/block/column_with_type_and_name.h" |
35 | | #include "core/call_on_type_index.h" |
36 | | #include "core/column/column.h" |
37 | | #include "core/column/column_array.h" |
38 | | #include "core/column/column_decimal.h" |
39 | | #include "core/column/column_nullable.h" |
40 | | #include "core/column/column_string.h" |
41 | | #include "core/data_type/data_type.h" |
42 | | #include "core/data_type/data_type_array.h" |
43 | | #include "core/data_type/data_type_nullable.h" |
44 | | #include "core/data_type/define_primitive_type.h" |
45 | | #include "core/data_type/primitive_type.h" |
46 | | #include "core/pod_array_fwd.h" |
47 | | #include "core/string_ref.h" |
48 | | #include "core/types.h" |
49 | | #include "exec/common/hash_table/hash.h" |
50 | | #include "exprs/function/function.h" |
51 | | |
52 | | namespace doris { |
53 | | class FunctionContext; |
54 | | } // namespace doris |
55 | | template <typename, typename> |
56 | | struct DefaultHash; |
57 | | |
58 | | namespace doris { |
59 | | |
60 | | class FunctionArrayDistinct : public IFunction { |
61 | | public: |
62 | | static constexpr auto name = "array_distinct"; |
63 | 2 | static FunctionPtr create() { return std::make_shared<FunctionArrayDistinct>(); } |
64 | | using NullMapType = PaddedPODArray<UInt8>; |
65 | | |
66 | | /// Get function name. |
67 | 1 | String get_name() const override { return name; } |
68 | | |
69 | 1 | bool is_variadic() const override { return false; } |
70 | | |
71 | 0 | size_t get_number_of_arguments() const override { return 1; } |
72 | | |
73 | 0 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { |
74 | 0 | DCHECK(arguments[0]->get_primitive_type() == TYPE_ARRAY) |
75 | 0 | << "first argument for function: " << name << " should be DataTypeArray" |
76 | 0 | << " and arguments[0] is " << arguments[0]->get_name(); |
77 | 0 | return arguments[0]; |
78 | 0 | } |
79 | | |
80 | | Status execute_impl(FunctionContext* context, Block& block, const ColumnNumbers& arguments, |
81 | 0 | uint32_t result, size_t input_rows_count) const override { |
82 | 0 | ColumnPtr src_column = |
83 | 0 | block.get_by_position(arguments[0]).column->convert_to_full_column_if_const(); |
84 | 0 | const auto& src_column_array = check_and_get_column<ColumnArray>(*src_column); |
85 | 0 | if (!src_column_array) { |
86 | 0 | return Status::RuntimeError( |
87 | 0 | fmt::format("unsupported types for function {}({})", get_name(), |
88 | 0 | block.get_by_position(arguments[0]).type->get_name())); |
89 | 0 | } |
90 | 0 | const auto& src_offsets = src_column_array->get_offsets(); |
91 | 0 | const auto* src_nested_column = &src_column_array->get_data(); |
92 | 0 | DCHECK(src_nested_column != nullptr); |
93 | |
|
94 | 0 | DataTypePtr src_column_type = block.get_by_position(arguments[0]).type; |
95 | 0 | auto nested_type = assert_cast<const DataTypeArray&>(*src_column_type).get_nested_type(); |
96 | 0 | auto dest_column_ptr = ColumnArray::create(nested_type->create_column(), |
97 | 0 | ColumnArray::ColumnOffsets::create()); |
98 | 0 | IColumn* dest_nested_column = &dest_column_ptr->get_data(); |
99 | 0 | auto& dest_offsets = dest_column_ptr->get_offsets(); |
100 | 0 | DCHECK(dest_nested_column != nullptr); |
101 | 0 | dest_nested_column->reserve(src_nested_column->size()); |
102 | 0 | dest_offsets.reserve(input_rows_count); |
103 | |
|
104 | 0 | const NullMapType* src_null_map = nullptr; |
105 | 0 | if (src_nested_column->is_nullable()) { |
106 | 0 | const auto* src_nested_nullable_col = |
107 | 0 | check_and_get_column<ColumnNullable>(*src_nested_column); |
108 | 0 | src_nested_column = src_nested_nullable_col->get_nested_column_ptr().get(); |
109 | 0 | src_null_map = &src_nested_nullable_col->get_null_map_column().get_data(); |
110 | 0 | } |
111 | |
|
112 | 0 | NullMapType* dest_null_map = nullptr; |
113 | 0 | if (dest_nested_column->is_nullable()) { |
114 | 0 | auto* dest_nested_nullable_col = reinterpret_cast<ColumnNullable*>(dest_nested_column); |
115 | 0 | dest_nested_column = dest_nested_nullable_col->get_nested_column_ptr().get(); |
116 | 0 | dest_null_map = &dest_nested_nullable_col->get_null_map_column().get_data(); |
117 | 0 | } |
118 | |
|
119 | 0 | auto res_val = _execute_by_type(*src_nested_column, src_offsets, *dest_nested_column, |
120 | 0 | dest_offsets, src_null_map, dest_null_map, nested_type); |
121 | 0 | if (!res_val) { |
122 | 0 | return Status::RuntimeError( |
123 | 0 | fmt::format("execute failed or unsupported types for function {}({})", |
124 | 0 | get_name(), block.get_by_position(arguments[0]).type->get_name())); |
125 | 0 | } |
126 | | |
127 | 0 | block.replace_by_position(result, std::move(dest_column_ptr)); |
128 | 0 | return Status::OK(); |
129 | 0 | } |
130 | | |
131 | | private: |
132 | | // Note: Here initially allocate a piece of memory for 2^5 = 32 elements. |
133 | | static constexpr size_t INITIAL_SIZE_DEGREE = 5; |
134 | | |
135 | | template <typename ColumnType> |
136 | | bool _execute_number(const IColumn& src_column, const ColumnArray::Offsets64& src_offsets, |
137 | | IColumn& dest_column, ColumnArray::Offsets64& dest_offsets, |
138 | 0 | const NullMapType* src_null_map, NullMapType* dest_null_map) const { |
139 | 0 | using NestType = typename ColumnType::value_type; |
140 | 0 | using ElementNativeType = typename NativeType<NestType>::Type; |
141 | |
|
142 | 0 | const auto* src_data_concrete = reinterpret_cast<const ColumnType*>(&src_column); |
143 | 0 | if (!src_data_concrete) { |
144 | 0 | return false; |
145 | 0 | } |
146 | 0 | const PaddedPODArray<NestType>& src_datas = src_data_concrete->get_data(); |
147 | |
|
148 | 0 | auto& dest_data_concrete = reinterpret_cast<ColumnType&>(dest_column); |
149 | 0 | PaddedPODArray<NestType>& dest_datas = dest_data_concrete.get_data(); |
150 | |
|
151 | 0 | using Set = phmap::flat_hash_set<ElementNativeType, DefaultHash<ElementNativeType>>; |
152 | 0 | Set set; |
153 | |
|
154 | 0 | size_t prev_src_offset = 0; |
155 | 0 | size_t res_offset = 0; |
156 | |
|
157 | 0 | for (auto curr_src_offset : src_offsets) { |
158 | 0 | set.clear(); |
159 | 0 | size_t null_size = 0; |
160 | 0 | for (size_t j = prev_src_offset; j < curr_src_offset; ++j) { |
161 | 0 | if (null_size != 0 && src_null_map && (*src_null_map)[j]) { |
162 | | // ignore duplicated nulls |
163 | 0 | continue; |
164 | 0 | } |
165 | 0 | if (src_null_map && (*src_null_map)[j]) { |
166 | 0 | DCHECK(dest_null_map != nullptr); |
167 | 0 | (*dest_null_map).push_back(true); |
168 | | // Note: here we need to add an element which will not use for output |
169 | | // because we expand the value of each offset |
170 | 0 | dest_datas.push_back(NestType()); |
171 | 0 | null_size++; |
172 | 0 | continue; |
173 | 0 | } |
174 | | |
175 | 0 | if (!set.contains(src_datas[j])) { |
176 | 0 | set.insert(src_datas[j]); |
177 | 0 | dest_datas.push_back(src_datas[j]); |
178 | 0 | if (dest_null_map) { |
179 | 0 | (*dest_null_map).push_back(false); |
180 | 0 | } |
181 | 0 | } |
182 | 0 | } |
183 | |
|
184 | 0 | res_offset += set.size() + null_size; |
185 | 0 | dest_offsets.push_back(res_offset); |
186 | 0 | prev_src_offset = curr_src_offset; |
187 | 0 | } |
188 | |
|
189 | 0 | return true; |
190 | 0 | } Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE27EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE36EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ Unexecuted instantiation: _ZNK5doris21FunctionArrayDistinct15_execute_numberINS_12ColumnVectorILNS_13PrimitiveTypeE37EEEEEbRKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS5_RSC_PKNS8_IhLm4096ESB_Lm16ELm15EEEPSH_ |
191 | | |
192 | | bool _execute_string(const IColumn& src_column, const ColumnArray::Offsets64& src_offsets, |
193 | | IColumn& dest_column, ColumnArray::Offsets64& dest_offsets, |
194 | 0 | const NullMapType* src_null_map, NullMapType* dest_null_map) const { |
195 | 0 | const auto* src_data_concrete = reinterpret_cast<const ColumnString*>(&src_column); |
196 | 0 | if (!src_data_concrete) { |
197 | 0 | return false; |
198 | 0 | } |
199 | | |
200 | 0 | auto& dest_column_string = reinterpret_cast<ColumnString&>(dest_column); |
201 | 0 | ColumnString::Chars& column_string_chars = dest_column_string.get_chars(); |
202 | 0 | ColumnString::Offsets& column_string_offsets = dest_column_string.get_offsets(); |
203 | 0 | column_string_chars.reserve(src_column.size()); |
204 | |
|
205 | 0 | using Set = phmap::flat_hash_set<StringRef, DefaultHash<StringRef>>; |
206 | 0 | Set set; |
207 | |
|
208 | 0 | size_t prev_src_offset = 0; |
209 | 0 | size_t res_offset = 0; |
210 | |
|
211 | 0 | for (auto curr_src_offset : src_offsets) { |
212 | 0 | set.clear(); |
213 | 0 | size_t null_size = 0; |
214 | 0 | for (size_t j = prev_src_offset; j < curr_src_offset; ++j) { |
215 | 0 | if (null_size != 0 && src_null_map && (*src_null_map)[j]) { |
216 | | // ignore duplicated nulls |
217 | 0 | continue; |
218 | 0 | } |
219 | 0 | if (src_null_map && (*src_null_map)[j]) { |
220 | 0 | DCHECK(dest_null_map != nullptr); |
221 | | // Note: here we need to update the offset of ColumnString |
222 | 0 | column_string_offsets.push_back(column_string_offsets.back()); |
223 | 0 | (*dest_null_map).push_back(true); |
224 | 0 | null_size++; |
225 | 0 | continue; |
226 | 0 | } |
227 | | |
228 | 0 | StringRef src_str_ref = src_data_concrete->get_data_at(j); |
229 | 0 | if (!set.contains(src_str_ref)) { |
230 | 0 | set.insert(src_str_ref); |
231 | | // copy the src data to column_string_chars |
232 | 0 | const size_t old_size = column_string_chars.size(); |
233 | 0 | const size_t new_size = old_size + src_str_ref.size; |
234 | 0 | column_string_chars.resize(new_size); |
235 | 0 | if (src_str_ref.size > 0) { |
236 | 0 | memcpy(column_string_chars.data() + old_size, src_str_ref.data, |
237 | 0 | src_str_ref.size); |
238 | 0 | } |
239 | 0 | column_string_offsets.push_back(new_size); |
240 | |
|
241 | 0 | if (dest_null_map) { |
242 | 0 | (*dest_null_map).push_back(false); |
243 | 0 | } |
244 | 0 | } |
245 | 0 | } |
246 | |
|
247 | 0 | res_offset += set.size() + null_size; |
248 | 0 | dest_offsets.push_back(res_offset); |
249 | 0 | prev_src_offset = curr_src_offset; |
250 | 0 | } |
251 | 0 | return true; |
252 | 0 | } |
253 | | |
254 | | bool _execute_by_type(const IColumn& src_column, const ColumnArray::Offsets64& src_offsets, |
255 | | IColumn& dest_column, ColumnArray::Offsets64& dest_offsets, |
256 | | const NullMapType* src_null_map, NullMapType* dest_null_map, |
257 | 0 | DataTypePtr& nested_type) const { |
258 | 0 | if (is_string_type(nested_type->get_primitive_type())) { |
259 | 0 | return _execute_string(src_column, src_offsets, dest_column, dest_offsets, src_null_map, |
260 | 0 | dest_null_map); |
261 | 0 | } |
262 | 0 | auto call = [&](const auto& type) -> bool { |
263 | 0 | using DispatchType = std::decay_t<decltype(type)>; |
264 | 0 | return _execute_number<typename DispatchType::ColumnType>(src_column, src_offsets, |
265 | 0 | dest_column, dest_offsets, |
266 | 0 | src_null_map, dest_null_map); |
267 | 0 | }; Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE2EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE3EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE4EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE5EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE6EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE7EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE8EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE9EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE11EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE25EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE26EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE12EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE27EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE42EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE36EEEEEbSO_ Unexecuted instantiation: _ZZNK5doris21FunctionArrayDistinct16_execute_by_typeERKNS_7IColumnERKNS_8PODArrayImLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS1_RS8_PKNS4_IhLm4096ES7_Lm16ELm15EEEPSD_RSt10shared_ptrIKNS_9IDataTypeEEENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE37EEEEEbSO_ |
268 | |
|
269 | 0 | return dispatch_switch_scalar(nested_type->get_primitive_type(), call); |
270 | 0 | } |
271 | | }; |
272 | | |
273 | | } // namespace doris |