Coverage Report

Created: 2026-06-27 10:26

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/vcase_expr.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
18
#pragma once
19
20
#include <string>
21
22
#include "common/exception.h"
23
#include "common/status.h"
24
#include "core/column/column_array.h"
25
#include "core/column/column_complex.h"
26
#include "core/column/column_const.h"
27
#include "core/column/column_decimal.h"
28
#include "core/column/column_map.h"
29
#include "core/column/column_nullable.h"
30
#include "core/column/column_struct.h"
31
#include "core/column/column_variant.h"
32
#include "core/data_type/define_primitive_type.h"
33
#include "core/data_type/primitive_type.h"
34
#include "exprs/function/function.h"
35
#include "exprs/function_context.h"
36
#include "exprs/vexpr.h"
37
38
namespace doris {
39
class RowDescriptor;
40
class RuntimeState;
41
class TExprNode;
42
43
class Block;
44
} // namespace doris
45
46
namespace doris {
47
48
class VCaseExpr final : public VExpr {
49
    ENABLE_FACTORY_CREATOR(VCaseExpr);
50
51
public:
52
    VCaseExpr(const TExprNode& node);
53
    ~VCaseExpr() override = default;
54
    Status execute_column_impl(VExprContext* context, const Block* block, const Selector* selector,
55
                               size_t count, ColumnPtr& result_column) const override;
56
    Status prepare(RuntimeState* state, const RowDescriptor& desc, VExprContext* context) override;
57
    Status open(RuntimeState* state, VExprContext* context,
58
                FunctionContext::FunctionStateScope scope) override;
59
    void close(VExprContext* context, FunctionContext::FunctionStateScope scope) override;
60
    const std::string& expr_name() const override;
61
    std::string debug_string() const override;
62
0
    bool has_else_expr() const { return _has_else_expr; }
63
1
    Status clone_node(VExprSPtr* cloned_expr) const override {
64
1
        DORIS_CHECK(cloned_expr != nullptr);
65
1
        auto node = clone_texpr_node();
66
1
        TCaseExpr case_node;
67
1
        case_node.__set_has_case_expr(false);
68
1
        case_node.__set_has_else_expr(_has_else_expr);
69
1
        node.__set_case_expr(case_node);
70
1
        *cloned_expr = VCaseExpr::create_shared(node);
71
1
        return Status::OK();
72
1
    }
73
74
private:
75
    template <typename IndexType, typename ColumnType>
76
    ColumnPtr _execute_update_result_impl(const IndexType* then_idx,
77
                                          std::vector<ColumnPtr>& then_columns,
78
1.92k
                                          size_t rows_count) const {
79
1.92k
        auto result_column_ptr = data_type()->create_column();
80
1.92k
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
65
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
65
            if (data_type()->is_nullable()) {
94
3
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
3
                                                                  then_columns, rows_count);
96
62
            } else {
97
62
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
62
                                                                   then_columns, rows_count);
99
62
            }
100
1.85k
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
14
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
14
                                                              then_columns, rows_count);
104
1.84k
        } else {
105
1.84k
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
1.84k
                                                           then_columns, rows_count);
107
1.84k
        }
108
1.92k
        return result_column_ptr;
109
1.92k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_9ColumnStrIjEEEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EEPKT_RSt6vectorIS8_SaIS8_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_11ColumnArrayEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_9ColumnMapEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnStructEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnVariantEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
1.63k
                                          size_t rows_count) const {
79
1.63k
        auto result_column_ptr = data_type()->create_column();
80
1.63k
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
1.63k
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
1
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
1
                                                              then_columns, rows_count);
104
1.63k
        } else {
105
1.63k
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
1.63k
                                                           then_columns, rows_count);
107
1.63k
        }
108
1.63k
        return result_column_ptr;
109
1.63k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
10
                                          size_t rows_count) const {
79
10
        auto result_column_ptr = data_type()->create_column();
80
10
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
10
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
10
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
10
                                                              then_columns, rows_count);
104
10
        } else {
105
0
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
0
                                                           then_columns, rows_count);
107
0
        }
108
10
        return result_column_ptr;
109
10
    }
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
137
                                          size_t rows_count) const {
79
137
        auto result_column_ptr = data_type()->create_column();
80
137
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
137
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
0
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
0
                                                              then_columns, rows_count);
104
137
        } else {
105
137
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
137
                                                           then_columns, rows_count);
107
137
        }
108
137
        return result_column_ptr;
109
137
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
3
                                          size_t rows_count) const {
79
3
        auto result_column_ptr = data_type()->create_column();
80
3
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
3
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
3
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
3
                                                              then_columns, rows_count);
104
3
        } else {
105
0
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
0
                                                           then_columns, rows_count);
107
0
        }
108
3
        return result_column_ptr;
109
3
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
68
                                          size_t rows_count) const {
79
68
        auto result_column_ptr = data_type()->create_column();
80
68
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
68
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
0
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
0
                                                              then_columns, rows_count);
104
68
        } else {
105
68
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
68
                                                           then_columns, rows_count);
107
68
        }
108
68
        return result_column_ptr;
109
68
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_9ColumnStrIjEEEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EEPKT_RSt6vectorIS8_SaIS8_EEm
Line
Count
Source
78
65
                                          size_t rows_count) const {
79
65
        auto result_column_ptr = data_type()->create_column();
80
65
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
65
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
65
            if (data_type()->is_nullable()) {
94
3
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
3
                                                                  then_columns, rows_count);
96
62
            } else {
97
62
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
62
                                                                   then_columns, rows_count);
99
62
            }
100
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
                                                              then_columns, rows_count);
104
        } else {
105
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
                                                           then_columns, rows_count);
107
        }
108
65
        return result_column_ptr;
109
65
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Line
Count
Source
78
2
                                          size_t rows_count) const {
79
2
        auto result_column_ptr = data_type()->create_column();
80
2
        result_column_ptr->reserve(rows_count);
81
        if constexpr (std::is_same_v<ColumnType, ColumnString> ||
82
                      std::is_same_v<ColumnType, ColumnBitmap> ||
83
                      std::is_same_v<ColumnType, ColumnArray> ||
84
                      std::is_same_v<ColumnType, ColumnMap> ||
85
                      std::is_same_v<ColumnType, ColumnStruct> ||
86
                      std::is_same_v<ColumnType, ColumnVariant> ||
87
                      std::is_same_v<ColumnType, ColumnHLL> ||
88
                      std::is_same_v<ColumnType, ColumnQuantileState> ||
89
                      std::is_same_v<ColumnType, ColumnIPv4> ||
90
                      std::is_same_v<ColumnType, ColumnIPv6>) {
91
            // result_column and all then_column is not nullable.
92
            // can't simd when type is string.
93
            if (data_type()->is_nullable()) {
94
                update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
95
                                                                  then_columns, rows_count);
96
            } else {
97
                update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx,
98
                                                                   then_columns, rows_count);
99
            }
100
2
        } else if (data_type()->is_nullable()) {
101
            // result_column and all then_column is nullable.
102
0
            update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx,
103
0
                                                              then_columns, rows_count);
104
2
        } else {
105
2
            update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx,
106
2
                                                           then_columns, rows_count);
107
2
        }
108
2
        return result_column_ptr;
109
2
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_11ColumnArrayEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_9ColumnMapEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnStructEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnVariantEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm
110
111
    template <typename IndexType>
112
    ColumnPtr _execute_update_result(const IndexType* then_idx,
113
                                     std::vector<ColumnPtr>& then_columns,
114
1.92k
                                     size_t rows_count) const {
115
1.92k
#define CASE_TYPE(ptype, coltype) \
116
1.92k
    case PrimitiveType::ptype:    \
117
1.92k
        return _execute_update_result_impl<IndexType, coltype>(then_idx, then_columns, rows_count);
118
119
1.92k
        switch (data_type()->get_primitive_type()) {
120
0
            CASE_TYPE(TYPE_BOOLEAN, ColumnUInt8)
121
1.63k
            CASE_TYPE(TYPE_TINYINT, ColumnInt8)
122
0
            CASE_TYPE(TYPE_SMALLINT, ColumnInt16)
123
10
            CASE_TYPE(TYPE_INT, ColumnInt32)
124
137
            CASE_TYPE(TYPE_BIGINT, ColumnInt64)
125
0
            CASE_TYPE(TYPE_LARGEINT, ColumnInt128)
126
0
            CASE_TYPE(TYPE_FLOAT, ColumnFloat32)
127
3
            CASE_TYPE(TYPE_DOUBLE, ColumnFloat64)
128
0
            CASE_TYPE(TYPE_DECIMAL32, ColumnDecimal32)
129
68
            CASE_TYPE(TYPE_DECIMAL64, ColumnDecimal64)
130
0
            CASE_TYPE(TYPE_DECIMAL256, ColumnDecimal256)
131
0
            CASE_TYPE(TYPE_DECIMAL128I, ColumnDecimal128V3)
132
0
            CASE_TYPE(TYPE_DECIMALV2, ColumnDecimal128V2)
133
0
            CASE_TYPE(TYPE_STRING, ColumnString)
134
0
            CASE_TYPE(TYPE_CHAR, ColumnString)
135
65
            CASE_TYPE(TYPE_VARCHAR, ColumnString)
136
0
            CASE_TYPE(TYPE_JSONB, ColumnString)
137
0
            CASE_TYPE(TYPE_DATE, ColumnDate)
138
0
            CASE_TYPE(TYPE_DATETIME, ColumnDateTime)
139
2
            CASE_TYPE(TYPE_DATEV2, ColumnDateV2)
140
0
            CASE_TYPE(TYPE_DATETIMEV2, ColumnDateTimeV2)
141
0
            CASE_TYPE(TYPE_TIMESTAMPTZ, ColumnTimeStampTz)
142
0
            CASE_TYPE(TYPE_IPV6, ColumnIPv6)
143
0
            CASE_TYPE(TYPE_IPV4, ColumnIPv4)
144
0
            CASE_TYPE(TYPE_ARRAY, ColumnArray)
145
0
            CASE_TYPE(TYPE_MAP, ColumnMap)
146
0
            CASE_TYPE(TYPE_STRUCT, ColumnStruct)
147
0
            CASE_TYPE(TYPE_VARIANT, ColumnVariant)
148
0
            CASE_TYPE(TYPE_BITMAP, ColumnBitmap)
149
0
            CASE_TYPE(TYPE_HLL, ColumnHLL)
150
0
            CASE_TYPE(TYPE_QUANTILE_STATE, ColumnQuantileState)
151
0
        default:
152
0
            throw Exception(ErrorCode::NOT_IMPLEMENTED_ERROR, "argument_type {} not supported",
153
0
                            data_type()->get_name());
154
1.92k
        }
155
1.92k
#undef CASE_TYPE
156
1.92k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr22_execute_update_resultItEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EEPKT_RSt6vectorIS6_SaIS6_EEm
_ZNK5doris9VCaseExpr22_execute_update_resultIhEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EEPKT_RSt6vectorIS6_SaIS6_EEm
Line
Count
Source
114
1.92k
                                     size_t rows_count) const {
115
1.92k
#define CASE_TYPE(ptype, coltype) \
116
1.92k
    case PrimitiveType::ptype:    \
117
1.92k
        return _execute_update_result_impl<IndexType, coltype>(then_idx, then_columns, rows_count);
118
119
1.92k
        switch (data_type()->get_primitive_type()) {
120
0
            CASE_TYPE(TYPE_BOOLEAN, ColumnUInt8)
121
1.63k
            CASE_TYPE(TYPE_TINYINT, ColumnInt8)
122
0
            CASE_TYPE(TYPE_SMALLINT, ColumnInt16)
123
10
            CASE_TYPE(TYPE_INT, ColumnInt32)
124
137
            CASE_TYPE(TYPE_BIGINT, ColumnInt64)
125
0
            CASE_TYPE(TYPE_LARGEINT, ColumnInt128)
126
0
            CASE_TYPE(TYPE_FLOAT, ColumnFloat32)
127
3
            CASE_TYPE(TYPE_DOUBLE, ColumnFloat64)
128
0
            CASE_TYPE(TYPE_DECIMAL32, ColumnDecimal32)
129
68
            CASE_TYPE(TYPE_DECIMAL64, ColumnDecimal64)
130
0
            CASE_TYPE(TYPE_DECIMAL256, ColumnDecimal256)
131
0
            CASE_TYPE(TYPE_DECIMAL128I, ColumnDecimal128V3)
132
0
            CASE_TYPE(TYPE_DECIMALV2, ColumnDecimal128V2)
133
0
            CASE_TYPE(TYPE_STRING, ColumnString)
134
0
            CASE_TYPE(TYPE_CHAR, ColumnString)
135
65
            CASE_TYPE(TYPE_VARCHAR, ColumnString)
136
0
            CASE_TYPE(TYPE_JSONB, ColumnString)
137
0
            CASE_TYPE(TYPE_DATE, ColumnDate)
138
0
            CASE_TYPE(TYPE_DATETIME, ColumnDateTime)
139
2
            CASE_TYPE(TYPE_DATEV2, ColumnDateV2)
140
0
            CASE_TYPE(TYPE_DATETIMEV2, ColumnDateTimeV2)
141
0
            CASE_TYPE(TYPE_TIMESTAMPTZ, ColumnTimeStampTz)
142
0
            CASE_TYPE(TYPE_IPV6, ColumnIPv6)
143
0
            CASE_TYPE(TYPE_IPV4, ColumnIPv4)
144
0
            CASE_TYPE(TYPE_ARRAY, ColumnArray)
145
0
            CASE_TYPE(TYPE_MAP, ColumnMap)
146
0
            CASE_TYPE(TYPE_STRUCT, ColumnStruct)
147
0
            CASE_TYPE(TYPE_VARIANT, ColumnVariant)
148
0
            CASE_TYPE(TYPE_BITMAP, ColumnBitmap)
149
0
            CASE_TYPE(TYPE_HLL, ColumnHLL)
150
0
            CASE_TYPE(TYPE_QUANTILE_STATE, ColumnQuantileState)
151
0
        default:
152
0
            throw Exception(ErrorCode::NOT_IMPLEMENTED_ERROR, "argument_type {} not supported",
153
0
                            data_type()->get_name());
154
1.92k
        }
155
1.92k
#undef CASE_TYPE
156
1.92k
    }
157
158
    template <typename IndexType, typename ColumnType, bool then_null>
159
    void update_result_normal(MutableColumnPtr& result_column_ptr,
160
                              const IndexType* __restrict then_idx,
161
79
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
79
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
79
        std::vector<uint8_t> is_consts(then_columns.size());
164
79
        std::vector<uint8_t> is_nullable(then_columns.size());
165
261
        for (size_t i = 0; i < then_columns.size(); i++) {
166
182
            if (!then_columns[i]) {
167
4
                continue;
168
4
            }
169
178
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
178
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
178
        }
172
173
79
        auto* raw_result_column = result_column_ptr.get();
174
323
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
244
            if (!_has_else_expr && !then_idx[row_idx]) {
176
8
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
8
                        ->insert_default();
178
8
                continue;
179
8
            }
180
236
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
236
            if constexpr (then_null) {
182
34
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
34
                        result_column_ptr.get());
184
34
                if (is_nullable[then_idx[row_idx]]) {
185
27
                    nullable->insert_from_with_type<ColumnType>(
186
27
                            *raw_then_columns[then_idx[row_idx]], target);
187
27
                } else {
188
7
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
7
                            nullable->get_nested_column_ptr().get());
190
7
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
7
                    nullable->push_false_to_nullmap(1);
192
7
                }
193
202
            } else {
194
202
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
202
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
202
            }
197
236
        }
198
79
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnStrIjEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnStrIjEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_11ColumnArrayELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_11ColumnArrayELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnMapELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnMapELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnStructELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnStructELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnVariantELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnVariantELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
161
1
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
1
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
1
        std::vector<uint8_t> is_consts(then_columns.size());
164
1
        std::vector<uint8_t> is_nullable(then_columns.size());
165
4
        for (size_t i = 0; i < then_columns.size(); i++) {
166
3
            if (!then_columns[i]) {
167
1
                continue;
168
1
            }
169
2
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
2
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
2
        }
172
173
1
        auto* raw_result_column = result_column_ptr.get();
174
3
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
2
            if (!_has_else_expr && !then_idx[row_idx]) {
176
0
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
0
                        ->insert_default();
178
0
                continue;
179
0
            }
180
2
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
2
            if constexpr (then_null) {
182
2
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
2
                        result_column_ptr.get());
184
2
                if (is_nullable[then_idx[row_idx]]) {
185
0
                    nullable->insert_from_with_type<ColumnType>(
186
0
                            *raw_then_columns[then_idx[row_idx]], target);
187
2
                } else {
188
2
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
2
                            nullable->get_nested_column_ptr().get());
190
2
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
2
                    nullable->push_false_to_nullmap(1);
192
2
                }
193
            } else {
194
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
            }
197
2
        }
198
1
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
161
10
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
10
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
10
        std::vector<uint8_t> is_consts(then_columns.size());
164
10
        std::vector<uint8_t> is_nullable(then_columns.size());
165
21
        for (size_t i = 0; i < then_columns.size(); i++) {
166
11
            if (!then_columns[i]) {
167
0
                continue;
168
0
            }
169
11
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
11
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
11
        }
172
173
10
        auto* raw_result_column = result_column_ptr.get();
174
30
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
20
            if (!_has_else_expr && !then_idx[row_idx]) {
176
0
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
0
                        ->insert_default();
178
0
                continue;
179
0
            }
180
20
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
20
            if constexpr (then_null) {
182
20
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
20
                        result_column_ptr.get());
184
20
                if (is_nullable[then_idx[row_idx]]) {
185
20
                    nullable->insert_from_with_type<ColumnType>(
186
20
                            *raw_then_columns[then_idx[row_idx]], target);
187
20
                } else {
188
0
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
0
                            nullable->get_nested_column_ptr().get());
190
0
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
0
                    nullable->push_false_to_nullmap(1);
192
0
                }
193
            } else {
194
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
            }
197
20
        }
198
10
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
161
3
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
3
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
3
        std::vector<uint8_t> is_consts(then_columns.size());
164
3
        std::vector<uint8_t> is_nullable(then_columns.size());
165
11
        for (size_t i = 0; i < then_columns.size(); i++) {
166
8
            if (!then_columns[i]) {
167
0
                continue;
168
0
            }
169
8
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
8
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
8
        }
172
173
3
        auto* raw_result_column = result_column_ptr.get();
174
13
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
10
            if (!_has_else_expr && !then_idx[row_idx]) {
176
0
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
0
                        ->insert_default();
178
0
                continue;
179
0
            }
180
10
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
10
            if constexpr (then_null) {
182
10
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
10
                        result_column_ptr.get());
184
10
                if (is_nullable[then_idx[row_idx]]) {
185
7
                    nullable->insert_from_with_type<ColumnType>(
186
7
                            *raw_then_columns[then_idx[row_idx]], target);
187
7
                } else {
188
3
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
3
                            nullable->get_nested_column_ptr().get());
190
3
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
3
                    nullable->push_false_to_nullmap(1);
192
3
                }
193
            } else {
194
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
            }
197
10
        }
198
3
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnStrIjEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm
Line
Count
Source
161
3
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
3
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
3
        std::vector<uint8_t> is_consts(then_columns.size());
164
3
        std::vector<uint8_t> is_nullable(then_columns.size());
165
8
        for (size_t i = 0; i < then_columns.size(); i++) {
166
5
            if (!then_columns[i]) {
167
3
                continue;
168
3
            }
169
2
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
2
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
2
        }
172
173
3
        auto* raw_result_column = result_column_ptr.get();
174
13
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
10
            if (!_has_else_expr && !then_idx[row_idx]) {
176
8
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
8
                        ->insert_default();
178
8
                continue;
179
8
            }
180
2
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
2
            if constexpr (then_null) {
182
2
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
2
                        result_column_ptr.get());
184
2
                if (is_nullable[then_idx[row_idx]]) {
185
0
                    nullable->insert_from_with_type<ColumnType>(
186
0
                            *raw_then_columns[then_idx[row_idx]], target);
187
2
                } else {
188
2
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
2
                            nullable->get_nested_column_ptr().get());
190
2
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
2
                    nullable->push_false_to_nullmap(1);
192
2
                }
193
            } else {
194
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
            }
197
2
        }
198
3
    }
_ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnStrIjEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm
Line
Count
Source
161
62
                              std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
162
62
        std::vector<ColumnPtr> raw_then_columns(then_columns.size());
163
62
        std::vector<uint8_t> is_consts(then_columns.size());
164
62
        std::vector<uint8_t> is_nullable(then_columns.size());
165
217
        for (size_t i = 0; i < then_columns.size(); i++) {
166
155
            if (!then_columns[i]) {
167
0
                continue;
168
0
            }
169
155
            std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]);
170
155
            is_nullable[i] = is_column_nullable(*raw_then_columns[i]);
171
155
        }
172
173
62
        auto* raw_result_column = result_column_ptr.get();
174
264
        for (int row_idx = 0; row_idx < rows_count; row_idx++) {
175
202
            if (!_has_else_expr && !then_idx[row_idx]) {
176
0
                assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column)
177
0
                        ->insert_default();
178
0
                continue;
179
0
            }
180
202
            size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx;
181
            if constexpr (then_null) {
182
                auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(
183
                        result_column_ptr.get());
184
                if (is_nullable[then_idx[row_idx]]) {
185
                    nullable->insert_from_with_type<ColumnType>(
186
                            *raw_then_columns[then_idx[row_idx]], target);
187
                } else {
188
                    auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(
189
                            nullable->get_nested_column_ptr().get());
190
                    nested->insert_from(*raw_then_columns[then_idx[row_idx]], target);
191
                    nullable->push_false_to_nullmap(1);
192
                }
193
202
            } else {
194
202
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
195
202
                        ->insert_from(*raw_then_columns[then_idx[row_idx]], target);
196
202
            }
197
202
        }
198
62
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_11ColumnArrayELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_11ColumnArrayELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnMapELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnMapELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnStructELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnStructELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnVariantELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnVariantELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
199
200
    template <typename IndexType, typename ColumnType>
201
    void update_result_auto_simd(MutableColumnPtr& result_column_ptr,
202
                                 const IndexType* __restrict then_idx,
203
1.84k
                                 std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
204
2.89k
        for (auto& then_ptr : then_columns) {
205
2.89k
            then_ptr = then_ptr->convert_to_full_column_if_const();
206
2.89k
        }
207
208
1.84k
        result_column_ptr->resize(rows_count);
209
1.84k
        auto* __restrict result_raw_data =
210
1.84k
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
211
1.84k
                        ->get_data()
212
1.84k
                        .data();
213
214
        // set default value
215
4.02k
        for (int i = 0; i < rows_count; i++) {
216
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
217
                          std::is_same_v<ColumnType, ColumnDateTime> ||
218
                          std::is_same_v<ColumnType, ColumnDateV2> ||
219
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
220
10
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
221
10
                result_raw_data[i] = ColumnType::default_value();
222
2.16k
            } else {
223
2.16k
                result_raw_data[i] = {};
224
2.16k
            }
225
2.17k
        }
226
227
4.73k
        for (IndexType i = 0; i < then_columns.size(); i++) {
228
2.89k
            if (!then_columns[i]) {
229
0
                continue;
230
0
            }
231
2.89k
            const auto* __restrict column_raw_data =
232
2.89k
                    assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>(
233
2.89k
                            then_columns[i].get())
234
2.89k
                            ->get_data()
235
2.89k
                            .data();
236
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
237
                          std::is_same_v<ColumnType, ColumnDateTime> ||
238
                          std::is_same_v<ColumnType, ColumnDateV2> ||
239
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
240
6
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
241
36
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
242
30
                    result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx]
243
30
                                                                        : result_raw_data[row_idx];
244
30
                }
245
2.88k
            } else {
246
6.66k
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
247
3.77k
                    result_raw_data[row_idx] +=
248
3.77k
                            typename ColumnType::value_type(then_idx[row_idx] == i) *
249
3.77k
                            column_raw_data[row_idx];
250
3.77k
                }
251
2.88k
            }
252
2.89k
        }
253
1.84k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
203
1.63k
                                 std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
204
2.51k
        for (auto& then_ptr : then_columns) {
205
2.51k
            then_ptr = then_ptr->convert_to_full_column_if_const();
206
2.51k
        }
207
208
1.63k
        result_column_ptr->resize(rows_count);
209
1.63k
        auto* __restrict result_raw_data =
210
1.63k
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
211
1.63k
                        ->get_data()
212
1.63k
                        .data();
213
214
        // set default value
215
3.38k
        for (int i = 0; i < rows_count; i++) {
216
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
217
                          std::is_same_v<ColumnType, ColumnDateTime> ||
218
                          std::is_same_v<ColumnType, ColumnDateV2> ||
219
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
220
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
221
                result_raw_data[i] = ColumnType::default_value();
222
1.74k
            } else {
223
1.74k
                result_raw_data[i] = {};
224
1.74k
            }
225
1.74k
        }
226
227
4.15k
        for (IndexType i = 0; i < then_columns.size(); i++) {
228
2.51k
            if (!then_columns[i]) {
229
0
                continue;
230
0
            }
231
2.51k
            const auto* __restrict column_raw_data =
232
2.51k
                    assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>(
233
2.51k
                            then_columns[i].get())
234
2.51k
                            ->get_data()
235
2.51k
                            .data();
236
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
237
                          std::is_same_v<ColumnType, ColumnDateTime> ||
238
                          std::is_same_v<ColumnType, ColumnDateV2> ||
239
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
240
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
241
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
242
                    result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx]
243
                                                                        : result_raw_data[row_idx];
244
                }
245
2.51k
            } else {
246
5.43k
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
247
2.91k
                    result_raw_data[row_idx] +=
248
2.91k
                            typename ColumnType::value_type(then_idx[row_idx] == i) *
249
2.91k
                            column_raw_data[row_idx];
250
2.91k
                }
251
2.51k
            }
252
2.51k
        }
253
1.63k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
203
137
                                 std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
204
204
        for (auto& then_ptr : then_columns) {
205
204
            then_ptr = then_ptr->convert_to_full_column_if_const();
206
204
        }
207
208
137
        result_column_ptr->resize(rows_count);
209
137
        auto* __restrict result_raw_data =
210
137
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
211
137
                        ->get_data()
212
137
                        .data();
213
214
        // set default value
215
444
        for (int i = 0; i < rows_count; i++) {
216
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
217
                          std::is_same_v<ColumnType, ColumnDateTime> ||
218
                          std::is_same_v<ColumnType, ColumnDateV2> ||
219
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
220
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
221
                result_raw_data[i] = ColumnType::default_value();
222
307
            } else {
223
307
                result_raw_data[i] = {};
224
307
            }
225
307
        }
226
227
341
        for (IndexType i = 0; i < then_columns.size(); i++) {
228
204
            if (!then_columns[i]) {
229
0
                continue;
230
0
            }
231
204
            const auto* __restrict column_raw_data =
232
204
                    assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>(
233
204
                            then_columns[i].get())
234
204
                            ->get_data()
235
204
                            .data();
236
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
237
                          std::is_same_v<ColumnType, ColumnDateTime> ||
238
                          std::is_same_v<ColumnType, ColumnDateV2> ||
239
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
240
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
241
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
242
                    result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx]
243
                                                                        : result_raw_data[row_idx];
244
                }
245
204
            } else {
246
763
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
247
559
                    result_raw_data[row_idx] +=
248
559
                            typename ColumnType::value_type(then_idx[row_idx] == i) *
249
559
                            column_raw_data[row_idx];
250
559
                }
251
204
            }
252
204
        }
253
137
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
203
68
                                 std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
204
164
        for (auto& then_ptr : then_columns) {
205
164
            then_ptr = then_ptr->convert_to_full_column_if_const();
206
164
        }
207
208
68
        result_column_ptr->resize(rows_count);
209
68
        auto* __restrict result_raw_data =
210
68
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
211
68
                        ->get_data()
212
68
                        .data();
213
214
        // set default value
215
184
        for (int i = 0; i < rows_count; i++) {
216
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
217
                          std::is_same_v<ColumnType, ColumnDateTime> ||
218
                          std::is_same_v<ColumnType, ColumnDateV2> ||
219
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
220
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
221
                result_raw_data[i] = ColumnType::default_value();
222
116
            } else {
223
116
                result_raw_data[i] = {};
224
116
            }
225
116
        }
226
227
232
        for (IndexType i = 0; i < then_columns.size(); i++) {
228
164
            if (!then_columns[i]) {
229
0
                continue;
230
0
            }
231
164
            const auto* __restrict column_raw_data =
232
164
                    assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>(
233
164
                            then_columns[i].get())
234
164
                            ->get_data()
235
164
                            .data();
236
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
237
                          std::is_same_v<ColumnType, ColumnDateTime> ||
238
                          std::is_same_v<ColumnType, ColumnDateV2> ||
239
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
240
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
241
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
242
                    result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx]
243
                                                                        : result_raw_data[row_idx];
244
                }
245
164
            } else {
246
468
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
247
304
                    result_raw_data[row_idx] +=
248
304
                            typename ColumnType::value_type(then_idx[row_idx] == i) *
249
304
                            column_raw_data[row_idx];
250
304
                }
251
164
            }
252
164
        }
253
68
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
_ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Line
Count
Source
203
2
                                 std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
204
6
        for (auto& then_ptr : then_columns) {
205
6
            then_ptr = then_ptr->convert_to_full_column_if_const();
206
6
        }
207
208
2
        result_column_ptr->resize(rows_count);
209
2
        auto* __restrict result_raw_data =
210
2
                assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get())
211
2
                        ->get_data()
212
2
                        .data();
213
214
        // set default value
215
12
        for (int i = 0; i < rows_count; i++) {
216
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
217
                          std::is_same_v<ColumnType, ColumnDateTime> ||
218
                          std::is_same_v<ColumnType, ColumnDateV2> ||
219
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
220
10
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
221
10
                result_raw_data[i] = ColumnType::default_value();
222
            } else {
223
                result_raw_data[i] = {};
224
            }
225
10
        }
226
227
8
        for (IndexType i = 0; i < then_columns.size(); i++) {
228
6
            if (!then_columns[i]) {
229
0
                continue;
230
0
            }
231
6
            const auto* __restrict column_raw_data =
232
6
                    assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>(
233
6
                            then_columns[i].get())
234
6
                            ->get_data()
235
6
                            .data();
236
            if constexpr (std::is_same_v<ColumnType, ColumnDate> ||
237
                          std::is_same_v<ColumnType, ColumnDateTime> ||
238
                          std::is_same_v<ColumnType, ColumnDateV2> ||
239
                          std::is_same_v<ColumnType, ColumnDateTimeV2> ||
240
6
                          std::is_same_v<ColumnType, ColumnTimeStampTz>) {
241
36
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
242
30
                    result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx]
243
30
                                                                        : result_raw_data[row_idx];
244
30
                }
245
            } else {
246
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
247
                    result_raw_data[row_idx] +=
248
                            typename ColumnType::value_type(then_idx[row_idx] == i) *
249
                            column_raw_data[row_idx];
250
                }
251
            }
252
6
        }
253
2
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm
254
255
    template <typename IndexType>
256
    ColumnPtr _execute_impl(const std::vector<ColumnPtr>& when_columns,
257
1.92k
                            std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
258
1.92k
        std::vector<IndexType> then_idx(rows_count, 0);
259
1.92k
        IndexType* __restrict then_idx_ptr = then_idx.data();
260
3.07k
        for (IndexType i = 0; i < when_columns.size(); i++) {
261
1.15k
            IndexType column_idx = i + 1;
262
1.15k
            auto [raw_when_column, is_consts] = unpack_if_const(when_columns[i]);
263
264
1.15k
            if (is_consts) {
265
0
                if (raw_when_column->get_bool(0)) {
266
0
                    for (int row_idx = 0; row_idx < rows_count; row_idx++) {
267
0
                        then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx]) * column_idx;
268
0
                    }
269
0
                    break;
270
0
                }
271
0
                continue;
272
0
            }
273
274
1.15k
            if (is_column_nullable(*raw_when_column)) {
275
688
                const auto* column_nullable_ptr =
276
688
                        assert_cast<const ColumnNullable*, TypeCheckOnRelease::DISABLE>(
277
688
                                raw_when_column.get());
278
688
                const auto* __restrict cond_raw_data =
279
688
                        assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>(
280
688
                                column_nullable_ptr->get_nested_column_ptr().get())
281
688
                                ->get_data()
282
688
                                .data();
283
688
                if (!column_nullable_ptr->has_null()) {
284
1.63k
                    for (int row_idx = 0; row_idx < rows_count; row_idx++) {
285
1.03k
                        then_idx_ptr[row_idx] |=
286
1.03k
                                (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx;
287
1.03k
                    }
288
608
                    continue;
289
608
                }
290
80
                const auto* __restrict cond_raw_nullmap =
291
80
                        column_nullable_ptr->get_null_map_column_ptr()->get_data().data();
292
506
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
293
426
                    then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx] * cond_raw_data[row_idx] *
294
426
                                              !cond_raw_nullmap[row_idx]) *
295
426
                                             column_idx;
296
426
                }
297
462
            } else {
298
462
                const auto* __restrict cond_raw_data =
299
462
                        assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>(
300
462
                                raw_when_column.get())
301
462
                                ->get_data()
302
462
                                .data();
303
1.05k
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
304
591
                    then_idx_ptr[row_idx] |=
305
591
                            (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx;
306
591
                }
307
462
            }
308
1.15k
        }
309
310
1.92k
        return _execute_update_result<IndexType>(then_idx_ptr, then_columns, rows_count);
311
1.92k
    }
Unexecuted instantiation: _ZNK5doris9VCaseExpr13_execute_implItEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EERKSt6vectorIS6_SaIS6_EERS9_m
_ZNK5doris9VCaseExpr13_execute_implIhEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EERKSt6vectorIS6_SaIS6_EERS9_m
Line
Count
Source
257
1.92k
                            std::vector<ColumnPtr>& then_columns, size_t rows_count) const {
258
1.92k
        std::vector<IndexType> then_idx(rows_count, 0);
259
1.92k
        IndexType* __restrict then_idx_ptr = then_idx.data();
260
3.07k
        for (IndexType i = 0; i < when_columns.size(); i++) {
261
1.15k
            IndexType column_idx = i + 1;
262
1.15k
            auto [raw_when_column, is_consts] = unpack_if_const(when_columns[i]);
263
264
1.15k
            if (is_consts) {
265
0
                if (raw_when_column->get_bool(0)) {
266
0
                    for (int row_idx = 0; row_idx < rows_count; row_idx++) {
267
0
                        then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx]) * column_idx;
268
0
                    }
269
0
                    break;
270
0
                }
271
0
                continue;
272
0
            }
273
274
1.15k
            if (is_column_nullable(*raw_when_column)) {
275
688
                const auto* column_nullable_ptr =
276
688
                        assert_cast<const ColumnNullable*, TypeCheckOnRelease::DISABLE>(
277
688
                                raw_when_column.get());
278
688
                const auto* __restrict cond_raw_data =
279
688
                        assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>(
280
688
                                column_nullable_ptr->get_nested_column_ptr().get())
281
688
                                ->get_data()
282
688
                                .data();
283
688
                if (!column_nullable_ptr->has_null()) {
284
1.63k
                    for (int row_idx = 0; row_idx < rows_count; row_idx++) {
285
1.03k
                        then_idx_ptr[row_idx] |=
286
1.03k
                                (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx;
287
1.03k
                    }
288
608
                    continue;
289
608
                }
290
80
                const auto* __restrict cond_raw_nullmap =
291
80
                        column_nullable_ptr->get_null_map_column_ptr()->get_data().data();
292
506
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
293
426
                    then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx] * cond_raw_data[row_idx] *
294
426
                                              !cond_raw_nullmap[row_idx]) *
295
426
                                             column_idx;
296
426
                }
297
462
            } else {
298
462
                const auto* __restrict cond_raw_data =
299
462
                        assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>(
300
462
                                raw_when_column.get())
301
462
                                ->get_data()
302
462
                                .data();
303
1.05k
                for (int row_idx = 0; row_idx < rows_count; row_idx++) {
304
591
                    then_idx_ptr[row_idx] |=
305
591
                            (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx;
306
591
                }
307
462
            }
308
1.15k
        }
309
310
1.92k
        return _execute_update_result<IndexType>(then_idx_ptr, then_columns, rows_count);
311
1.92k
    }
312
313
    bool _has_else_expr;
314
315
    inline static const std::string FUNCTION_NAME = "case";
316
    inline static const std::string EXPR_NAME = "vcase expr";
317
};
318
} // namespace doris