Coverage Report

Created: 2026-04-10 12:12

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/information_schema/schema_scanner.cpp
Line
Count
Source
1
// Licensed to the Apache Software Foundation (ASF) under one
2
// or more contributor license agreements.  See the NOTICE file
3
// distributed with this work for additional information
4
// regarding copyright ownership.  The ASF licenses this file
5
// to you under the Apache License, Version 2.0 (the
6
// "License"); you may not use this file except in compliance
7
// with the License.  You may obtain a copy of the License at
8
//
9
//   http://www.apache.org/licenses/LICENSE-2.0
10
//
11
// Unless required by applicable law or agreed to in writing,
12
// software distributed under the License is distributed on an
13
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
// KIND, either express or implied.  See the License for the
15
// specific language governing permissions and limitations
16
// under the License.
17
18
#include "information_schema/schema_scanner.h"
19
20
#include <gen_cpp/Descriptors_types.h>
21
#include <gen_cpp/Types_types.h>
22
#include <glog/logging.h>
23
#include <string.h>
24
25
#include <new>
26
#include <ostream>
27
#include <utility>
28
29
#include "core/block/block.h"
30
#include "core/block/column_with_type_and_name.h"
31
#include "core/column/column.h"
32
#include "core/column/column_complex.h"
33
#include "core/column/column_nullable.h"
34
#include "core/column/column_string.h"
35
#include "core/column/column_vector.h"
36
#include "core/data_type/data_type.h"
37
#include "core/data_type/data_type_factory.hpp"
38
#include "core/data_type/define_primitive_type.h"
39
#include "core/data_type/primitive_type.h"
40
#include "core/packed_int128.h"
41
#include "core/string_ref.h"
42
#include "core/types.h"
43
#include "core/value/hll.h"
44
#include "exec/pipeline/dependency.h"
45
#include "exprs/function/cast/cast_to_date_or_datetime_impl.hpp"
46
#include "information_schema/schema_active_queries_scanner.h"
47
#include "information_schema/schema_authentication_integrations_scanner.h"
48
#include "information_schema/schema_backend_active_tasks.h"
49
#include "information_schema/schema_backend_configuration_scanner.h"
50
#include "information_schema/schema_backend_kerberos_ticket_cache.h"
51
#include "information_schema/schema_catalog_meta_cache_stats_scanner.h"
52
#include "information_schema/schema_charsets_scanner.h"
53
#include "information_schema/schema_cluster_snapshot_properties_scanner.h"
54
#include "information_schema/schema_cluster_snapshots_scanner.h"
55
#include "information_schema/schema_collations_scanner.h"
56
#include "information_schema/schema_column_data_sizes_scanner.h"
57
#include "information_schema/schema_columns_scanner.h"
58
#include "information_schema/schema_compaction_tasks_scanner.h"
59
#include "information_schema/schema_database_properties_scanner.h"
60
#include "information_schema/schema_dummy_scanner.h"
61
#include "information_schema/schema_encryption_keys_scanner.h"
62
#include "information_schema/schema_file_cache_info_scanner.h"
63
#include "information_schema/schema_file_cache_statistics.h"
64
#include "information_schema/schema_files_scanner.h"
65
#include "information_schema/schema_load_job_scanner.h"
66
#include "information_schema/schema_metadata_name_ids_scanner.h"
67
#include "information_schema/schema_partitions_scanner.h"
68
#include "information_schema/schema_processlist_scanner.h"
69
#include "information_schema/schema_profiling_scanner.h"
70
#include "information_schema/schema_role_mappings_scanner.h"
71
#include "information_schema/schema_routine_load_job_scanner.h"
72
#include "information_schema/schema_rowsets_scanner.h"
73
#include "information_schema/schema_schema_privileges_scanner.h"
74
#include "information_schema/schema_schemata_scanner.h"
75
#include "information_schema/schema_sql_block_rule_status_scanner.h"
76
#include "information_schema/schema_table_options_scanner.h"
77
#include "information_schema/schema_table_privileges_scanner.h"
78
#include "information_schema/schema_table_properties_scanner.h"
79
#include "information_schema/schema_table_stream_consumption_scanner.h"
80
#include "information_schema/schema_table_streams_scanner.h"
81
#include "information_schema/schema_tables_scanner.h"
82
#include "information_schema/schema_tablets_scanner.h"
83
#include "information_schema/schema_user_privileges_scanner.h"
84
#include "information_schema/schema_user_scanner.h"
85
#include "information_schema/schema_variables_scanner.h"
86
#include "information_schema/schema_view_dependency_scanner.h"
87
#include "information_schema/schema_views_scanner.h"
88
#include "information_schema/schema_workload_group_privileges.h"
89
#include "information_schema/schema_workload_group_resource_usage_scanner.h"
90
#include "information_schema/schema_workload_groups_scanner.h"
91
#include "information_schema/schema_workload_sched_policy_scanner.h"
92
#include "runtime/fragment_mgr.h"
93
#include "util/string_util.h"
94
95
namespace doris {
96
class ObjectPool;
97
98
SchemaScanner::SchemaScanner(const std::vector<ColumnDesc>& columns, TSchemaTableType::type type)
99
4.62k
        : _is_init(false), _columns(columns), _schema_table_type(type) {}
100
101
4.63k
SchemaScanner::~SchemaScanner() = default;
102
103
4
Status SchemaScanner::start(RuntimeState* state) {
104
4
    if (!_is_init) {
105
0
        return Status::InternalError("call Start before Init.");
106
0
    }
107
108
4
    return Status::OK();
109
4
}
110
111
10.1k
Status SchemaScanner::get_next_block(RuntimeState* state, Block* block, bool* eos) {
112
10.1k
    if (_data_block == nullptr) {
113
0
        return Status::InternalError("No data left!");
114
0
    }
115
10.1k
    DCHECK(_async_thread_running == false);
116
10.1k
    RETURN_IF_ERROR(_scanner_status.status());
117
163k
    for (size_t i = 0; i < block->columns(); i++) {
118
153k
        std::move(*block->get_by_position(i).column)
119
153k
                .mutate()
120
153k
                ->insert_range_from(*_data_block->get_by_position(i).column, 0,
121
153k
                                    _data_block->rows());
122
153k
    }
123
10.1k
    _data_block->clear_column_data();
124
10.1k
    *eos = _eos;
125
10.1k
    if (!*eos) {
126
7.80k
        RETURN_IF_ERROR(get_next_block_async(state));
127
7.80k
    }
128
10.1k
    return Status::OK();
129
10.1k
}
130
131
10.1k
Status SchemaScanner::get_next_block_async(RuntimeState* state) {
132
10.1k
    _dependency->block();
133
10.1k
    auto task_ctx = state->get_task_execution_context();
134
10.1k
    RETURN_IF_ERROR(ExecEnv::GetInstance()->fragment_mgr()->get_thread_pool()->submit_func(
135
10.1k
            [this, task_ctx, state]() {
136
10.1k
                auto task_lock = task_ctx.lock();
137
10.1k
                if (task_lock == nullptr) {
138
10.1k
                    return;
139
10.1k
                }
140
10.1k
                DCHECK(_async_thread_running == false);
141
10.1k
                SCOPED_ATTACH_TASK(state);
142
10.1k
                _async_thread_running = true;
143
10.1k
                if (!_opened) {
144
10.1k
                    _data_block = Block::create_unique();
145
10.1k
                    _init_block(_data_block.get());
146
10.1k
                    _scanner_status.update(start(state));
147
10.1k
                    _opened = true;
148
10.1k
                }
149
10.1k
                bool eos = false;
150
10.1k
                auto call_next_block_internal = [&]() -> Status {
151
10.1k
                    RETURN_IF_CATCH_EXCEPTION(
152
10.1k
                            { return get_next_block_internal(_data_block.get(), &eos); });
153
10.1k
                };
154
10.1k
                _scanner_status.update(call_next_block_internal());
155
10.1k
                _eos = eos;
156
10.1k
                _async_thread_running = false;
157
10.1k
                _dependency->set_ready();
158
10.1k
            }));
159
10.1k
    return Status::OK();
160
10.1k
}
161
162
2.31k
Status SchemaScanner::init(RuntimeState* state, SchemaScannerParam* param, ObjectPool* pool) {
163
2.31k
    if (_is_init) {
164
0
        return Status::OK();
165
0
    }
166
2.31k
    if (nullptr == param || nullptr == pool) {
167
0
        return Status::InternalError("invalid parameter");
168
0
    }
169
170
2.31k
    _param = param;
171
2.31k
    _timezone = state->timezone();
172
2.31k
    _timezone_obj = state->timezone_obj();
173
2.31k
    _is_init = true;
174
175
2.31k
    if (_param->profile) {
176
2.31k
        _get_db_timer = ADD_TIMER(_param->profile, "GetDbTime");
177
2.31k
        _get_table_timer = ADD_TIMER(_param->profile, "GetTableTime");
178
2.31k
        _get_describe_timer = ADD_TIMER(_param->profile, "GetDescribeTime");
179
2.31k
        _fill_block_timer = ADD_TIMER(_param->profile, "FillBlockTime");
180
2.31k
    }
181
182
2.31k
    return Status::OK();
183
2.31k
}
184
185
4.62k
std::unique_ptr<SchemaScanner> SchemaScanner::create(TSchemaTableType::type type) {
186
4.62k
    switch (type) {
187
806
    case TSchemaTableType::SCH_TABLES:
188
806
        return SchemaTablesScanner::create_unique();
189
38
    case TSchemaTableType::SCH_SCHEMATA:
190
38
        return SchemaSchemataScanner::create_unique();
191
154
    case TSchemaTableType::SCH_COLUMNS:
192
154
        return SchemaColumnsScanner::create_unique();
193
4
    case TSchemaTableType::SCH_CHARSETS:
194
4
        return SchemaCharsetsScanner::create_unique();
195
4
    case TSchemaTableType::SCH_COLLATIONS:
196
4
        return SchemaCollationsScanner::create_unique();
197
4
    case TSchemaTableType::SCH_GLOBAL_VARIABLES:
198
4
        return SchemaVariablesScanner::create_unique(TVarType::GLOBAL);
199
70
    case TSchemaTableType::SCH_SESSION_VARIABLES:
200
70
    case TSchemaTableType::SCH_VARIABLES:
201
70
        return SchemaVariablesScanner::create_unique(TVarType::SESSION);
202
14
    case TSchemaTableType::SCH_VIEWS:
203
14
        return SchemaViewsScanner::create_unique();
204
12
    case TSchemaTableType::SCH_TABLE_PRIVILEGES:
205
12
        return SchemaTablePrivilegesScanner::create_unique();
206
8
    case TSchemaTableType::SCH_SCHEMA_PRIVILEGES:
207
8
        return SchemaSchemaPrivilegesScanner::create_unique();
208
4
    case TSchemaTableType::SCH_USER_PRIVILEGES:
209
4
        return SchemaUserPrivilegesScanner::create_unique();
210
4
    case TSchemaTableType::SCH_FILES:
211
4
        return SchemaFilesScanner::create_unique();
212
40
    case TSchemaTableType::SCH_PARTITIONS:
213
40
        return SchemaPartitionsScanner::create_unique();
214
2
    case TSchemaTableType::SCH_BACKEND_CONFIGURATION:
215
2
        return SchemaBackendConfigurationScanner::create_unique();
216
18
    case TSchemaTableType::SCH_ROWSETS:
217
18
        return SchemaRowsetsScanner::create_unique();
218
14
    case TSchemaTableType::SCH_METADATA_NAME_IDS:
219
14
        return SchemaMetadataNameIdsScanner::create_unique();
220
4
    case TSchemaTableType::SCH_PROFILING:
221
4
        return SchemaProfilingScanner::create_unique();
222
1.21k
    case TSchemaTableType::SCH_BACKEND_ACTIVE_TASKS:
223
1.21k
        return SchemaBackendActiveTasksScanner::create_unique();
224
1.22k
    case TSchemaTableType::SCH_ACTIVE_QUERIES:
225
1.22k
        return SchemaActiveQueriesScanner::create_unique();
226
52
    case TSchemaTableType::SCH_WORKLOAD_GROUPS:
227
52
        return SchemaWorkloadGroupsScanner::create_unique();
228
20
    case TSchemaTableType::SCH_PROCESSLIST:
229
20
        return SchemaProcessListScanner::create_unique();
230
2
    case TSchemaTableType::SCH_USER:
231
2
        return SchemaUserScanner::create_unique();
232
16
    case TSchemaTableType::SCH_WORKLOAD_POLICY:
233
16
        return SchemaWorkloadSchedulePolicyScanner::create_unique();
234
12
    case TSchemaTableType::SCH_TABLE_OPTIONS:
235
12
        return SchemaTableOptionsScanner::create_unique();
236
26
    case TSchemaTableType::SCH_WORKLOAD_GROUP_PRIVILEGES:
237
26
        return SchemaWorkloadGroupPrivilegesScanner::create_unique();
238
6
    case TSchemaTableType::SCH_WORKLOAD_GROUP_RESOURCE_USAGE:
239
6
        return SchemaBackendWorkloadGroupResourceUsage::create_unique();
240
16
    case TSchemaTableType::SCH_TABLE_PROPERTIES:
241
16
        return SchemaTablePropertiesScanner::create_unique();
242
12
    case TSchemaTableType::SCH_DATABASE_PROPERTIES:
243
12
        return SchemaDatabasePropertiesScanner::create_unique();
244
102
    case TSchemaTableType::SCH_FILE_CACHE_STATISTICS:
245
102
        return SchemaFileCacheStatisticsScanner::create_unique();
246
18
    case TSchemaTableType::SCH_CATALOG_META_CACHE_STATISTICS:
247
18
        return SchemaCatalogMetaCacheStatsScanner::create_unique();
248
2
    case TSchemaTableType::SCH_BACKEND_KERBEROS_TICKET_CACHE:
249
2
        return SchemaBackendKerberosTicketCacheScanner::create_unique();
250
6
    case TSchemaTableType::SCH_ROUTINE_LOAD_JOBS:
251
6
        return SchemaRoutineLoadJobScanner::create_unique();
252
4
    case TSchemaTableType::SCH_LOAD_JOBS:
253
4
        return SchemaLoadJobScanner::create_unique();
254
2
    case TSchemaTableType::SCH_BACKEND_TABLETS:
255
2
        return SchemaTabletsScanner::create_unique();
256
16
    case TSchemaTableType::SCH_VIEW_DEPENDENCY:
257
16
        return SchemaViewDependencyScanner::create_unique();
258
6
    case TSchemaTableType::SCH_SQL_BLOCK_RULE_STATUS:
259
6
        return SchemaSqlBlockRuleStatusScanner::create_unique();
260
0
    case TSchemaTableType::SCH_ENCRYPTION_KEYS:
261
0
        return SchemaEncryptionKeysScanner::create_unique();
262
4
    case TSchemaTableType::SCH_CLUSTER_SNAPSHOTS:
263
4
        return SchemaClusterSnapshotsScanner::create_unique();
264
2
    case TSchemaTableType::SCH_CLUSTER_SNAPSHOT_PROPERTIES:
265
2
        return SchemaClusterSnapshotPropertiesScanner::create_unique();
266
6
    case TSchemaTableType::SCH_COLUMN_DATA_SIZES:
267
6
        return SchemaColumnDataSizesScanner::create_unique();
268
2
    case TSchemaTableType::SCH_FILE_CACHE_INFO:
269
2
        return SchemaFileCacheInfoScanner::create_unique();
270
4
    case TSchemaTableType::SCH_AUTHENTICATION_INTEGRATIONS:
271
4
        return SchemaAuthenticationIntegrationsScanner::create_unique();
272
7
    case TSchemaTableType::SCH_ROLE_MAPPINGS:
273
7
        return SchemaRoleMappingsScanner::create_unique();
274
4
    case TSchemaTableType::SCH_TABLE_STREAMS:
275
4
        return SchemaTableStreamsScanner::create_unique();
276
4
    case TSchemaTableType::SCH_TABLE_STREAM_CONSUMPTION:
277
4
        return SchemaTableStreamConsumptionScanner::create_unique();
278
12
    case TSchemaTableType::SCH_BE_COMPACTION_TASKS:
279
12
        return SchemaCompactionTasksScanner::create_unique();
280
620
    default:
281
620
        return SchemaDummyScanner::create_unique();
282
0
        break;
283
4.62k
    }
284
4.62k
}
285
286
2.31k
void SchemaScanner::_init_block(Block* src_block) {
287
2.31k
    const std::vector<SchemaScanner::ColumnDesc>& columns_desc(get_column_desc());
288
32.0k
    for (int i = 0; i < columns_desc.size(); ++i) {
289
29.7k
        auto data_type = DataTypeFactory::instance().create_data_type(columns_desc[i].type, true);
290
29.7k
        src_block->insert(
291
29.7k
                ColumnWithTypeAndName(data_type->create_column(), data_type, columns_desc[i].name));
292
29.7k
    }
293
2.31k
}
294
295
Status SchemaScanner::fill_dest_column_for_range(Block* block, size_t pos,
296
62.3k
                                                 const std::vector<void*>& datas) {
297
62.3k
    const ColumnDesc& col_desc = _columns[pos];
298
62.3k
    MutableColumnPtr column_ptr;
299
62.3k
    column_ptr = std::move(*block->get_by_position(pos).column).assume_mutable();
300
62.3k
    IColumn* col_ptr = column_ptr.get();
301
302
62.3k
    auto* nullable_column = reinterpret_cast<ColumnNullable*>(col_ptr);
303
304
    // Resize in advance to improve insertion efficiency.
305
62.3k
    size_t fill_num = datas.size();
306
62.3k
    col_ptr = &nullable_column->get_nested_column();
307
5.89M
    for (int i = 0; i < fill_num; ++i) {
308
5.82M
        auto* data = datas[i];
309
5.82M
        if (data == nullptr) {
310
            // For nested column need not insert default.
311
387k
            nullable_column->insert_data(nullptr, 0);
312
387k
            continue;
313
5.43M
        } else {
314
5.43M
            nullable_column->push_false_to_nullmap(1);
315
5.43M
        }
316
5.43M
        switch (col_desc.type) {
317
0
        case TYPE_HLL: {
318
0
            auto* hll_slot = reinterpret_cast<HyperLogLog*>(data);
319
0
            assert_cast<ColumnHLL*>(col_ptr)->get_data().emplace_back(*hll_slot);
320
0
            break;
321
0
        }
322
1.33M
        case TYPE_VARCHAR:
323
1.33M
        case TYPE_CHAR:
324
1.40M
        case TYPE_STRING: {
325
1.40M
            auto* str_slot = reinterpret_cast<StringRef*>(data);
326
1.40M
            assert_cast<ColumnString*>(col_ptr)->insert_data(str_slot->data, str_slot->size);
327
1.40M
            break;
328
1.33M
        }
329
330
13.5k
        case TYPE_BOOLEAN: {
331
13.5k
            uint8_t num = *reinterpret_cast<bool*>(data);
332
13.5k
            assert_cast<ColumnBool*>(col_ptr)->insert_value(num);
333
13.5k
            break;
334
1.33M
        }
335
336
0
        case TYPE_TINYINT: {
337
0
            int8_t num = *reinterpret_cast<int8_t*>(data);
338
0
            assert_cast<ColumnInt8*>(col_ptr)->insert_value(num);
339
0
            break;
340
1.33M
        }
341
342
0
        case TYPE_SMALLINT: {
343
0
            int16_t num = *reinterpret_cast<int16_t*>(data);
344
0
            assert_cast<ColumnInt16*>(col_ptr)->insert_value(num);
345
0
            break;
346
1.33M
        }
347
348
324k
        case TYPE_INT: {
349
324k
            int32_t num = *reinterpret_cast<int32_t*>(data);
350
324k
            assert_cast<ColumnInt32*>(col_ptr)->insert_value(num);
351
324k
            break;
352
1.33M
        }
353
354
3.39M
        case TYPE_BIGINT: {
355
3.39M
            int64_t num = *reinterpret_cast<int64_t*>(data);
356
3.39M
            assert_cast<ColumnInt64*>(col_ptr)->insert_value(num);
357
3.39M
            break;
358
1.33M
        }
359
360
163
        case TYPE_LARGEINT: {
361
163
            __int128 num;
362
163
            memcpy(&num, data, sizeof(__int128));
363
163
            assert_cast<ColumnInt128*>(col_ptr)->insert_value(num);
364
163
            break;
365
1.33M
        }
366
367
0
        case TYPE_FLOAT: {
368
0
            float num = *reinterpret_cast<float*>(data);
369
0
            assert_cast<ColumnFloat32*>(col_ptr)->insert_value(num);
370
0
            break;
371
1.33M
        }
372
373
0
        case TYPE_DOUBLE: {
374
0
            double num = *reinterpret_cast<double*>(data);
375
0
            assert_cast<ColumnFloat64*>(col_ptr)->insert_value(num);
376
0
            break;
377
1.33M
        }
378
379
0
        case TYPE_DATE: {
380
0
            assert_cast<ColumnDate*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
381
0
            break;
382
1.33M
        }
383
384
0
        case TYPE_DATEV2: {
385
0
            assert_cast<ColumnDateV2*>(col_ptr)->insert_value(
386
0
                    *reinterpret_cast<DateV2Value<DateV2ValueType>*>(data));
387
0
            break;
388
1.33M
        }
389
390
313k
        case TYPE_DATETIME: {
391
313k
            assert_cast<ColumnDateTime*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
392
313k
            break;
393
1.33M
        }
394
395
167
        case TYPE_DATETIMEV2: {
396
167
            assert_cast<ColumnDateTimeV2*>(col_ptr)->insert_value(
397
167
                    *reinterpret_cast<DateV2Value<DateTimeV2ValueType>*>(data));
398
167
            break;
399
1.33M
        }
400
401
0
        case TYPE_TIMESTAMPTZ: {
402
0
            assert_cast<ColumnTimeStampTz*>(col_ptr)->insert_value(
403
0
                    *reinterpret_cast<TimestampTzValue*>(data));
404
0
            break;
405
1.33M
        }
406
407
0
        case TYPE_DECIMALV2: {
408
0
            const Int128 num = (reinterpret_cast<PackedInt128*>(data))->value;
409
0
            assert_cast<ColumnDecimal128V2*>(col_ptr)->insert_data(
410
0
                    reinterpret_cast<const char*>(&num), 0);
411
0
            break;
412
1.33M
        }
413
0
        case TYPE_DECIMAL128I: {
414
0
            const Int128 num = (reinterpret_cast<PackedInt128*>(data))->value;
415
0
            assert_cast<ColumnDecimal128V3*>(col_ptr)->insert_data(
416
0
                    reinterpret_cast<const char*>(&num), 0);
417
0
            break;
418
1.33M
        }
419
420
0
        case TYPE_DECIMAL32: {
421
0
            const int32_t num = *reinterpret_cast<int32_t*>(data);
422
0
            assert_cast<ColumnDecimal32*>(col_ptr)->insert_data(reinterpret_cast<const char*>(&num),
423
0
                                                                0);
424
0
            break;
425
1.33M
        }
426
427
0
        case TYPE_DECIMAL64: {
428
0
            const int64_t num = *reinterpret_cast<int64_t*>(data);
429
0
            assert_cast<ColumnDecimal64*>(col_ptr)->insert_data(reinterpret_cast<const char*>(&num),
430
0
                                                                0);
431
0
            break;
432
1.33M
        }
433
434
0
        default: {
435
0
            DCHECK(false) << "bad slot type: " << col_desc.type;
436
0
            std::stringstream ss;
437
0
            ss << "Fail to convert schema type:'" << col_desc.type << " on column:`"
438
0
               << std::string(col_desc.name) + "`";
439
0
            return Status::InternalError(ss.str());
440
1.33M
        }
441
5.43M
        }
442
5.43M
    }
443
69.0k
    return Status::OK();
444
62.3k
}
445
446
0
std::string SchemaScanner::get_db_from_full_name(const std::string& full_name) {
447
0
    std::vector<std::string> part = split(full_name, ".");
448
0
    if (part.size() == 2) {
449
0
        return part[1];
450
0
    }
451
0
    return full_name;
452
0
}
453
454
Status SchemaScanner::insert_block_column(TCell cell, int col_index, Block* block,
455
1.53M
                                          PrimitiveType type) {
456
1.53M
    MutableColumnPtr mutable_col_ptr;
457
1.53M
    mutable_col_ptr = std::move(*block->get_by_position(col_index).column).assume_mutable();
458
1.53M
    auto* nullable_column = reinterpret_cast<ColumnNullable*>(mutable_col_ptr.get());
459
1.53M
    IColumn* col_ptr = &nullable_column->get_nested_column();
460
461
1.53M
    switch (type) {
462
155k
    case TYPE_BIGINT: {
463
155k
        reinterpret_cast<ColumnInt64*>(col_ptr)->insert_value(cell.longVal);
464
155k
        break;
465
0
    }
466
467
52.2k
    case TYPE_INT: {
468
52.2k
        reinterpret_cast<ColumnInt32*>(col_ptr)->insert_value(cell.intVal);
469
52.2k
        break;
470
0
    }
471
472
0
    case TYPE_FLOAT: {
473
0
        assert_cast<ColumnFloat32*>(col_ptr)->insert_value(cell.doubleVal);
474
0
        break;
475
0
    }
476
477
6.99k
    case TYPE_DOUBLE: {
478
6.99k
        assert_cast<ColumnFloat64*>(col_ptr)->insert_value(cell.doubleVal);
479
6.99k
        break;
480
0
    }
481
482
10.5k
    case TYPE_BOOLEAN: {
483
10.5k
        reinterpret_cast<ColumnUInt8*>(col_ptr)->insert_value(cell.boolVal);
484
10.5k
        break;
485
0
    }
486
487
550k
    case TYPE_STRING:
488
1.29M
    case TYPE_VARCHAR:
489
1.29M
    case TYPE_CHAR: {
490
1.29M
        reinterpret_cast<ColumnString*>(col_ptr)->insert_data(cell.stringVal.data(),
491
1.29M
                                                              cell.stringVal.size());
492
1.29M
        break;
493
1.29M
    }
494
495
17.4k
    case TYPE_DATETIME: {
496
17.4k
        std::vector<void*> datas(1);
497
17.4k
        VecDateTimeValue src[1];
498
17.4k
        CastParameters params;
499
17.4k
        CastToDateOrDatetime::from_string_non_strict_mode<DatelikeTargetType::DATE_TIME>(
500
17.4k
                {cell.stringVal.data(), cell.stringVal.size()}, src[0], nullptr, params);
501
17.4k
        datas[0] = src;
502
17.4k
        auto data = datas[0];
503
17.4k
        reinterpret_cast<ColumnDateTime*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
504
17.4k
        break;
505
1.29M
    }
506
0
    default: {
507
0
        std::stringstream ss;
508
0
        ss << "unsupported column type:" << type;
509
0
        return Status::InternalError(ss.str());
510
1.29M
    }
511
1.53M
    }
512
1.53M
    nullable_column->push_false_to_nullmap(1);
513
1.53M
    return Status::OK();
514
1.53M
}
515
516
} // namespace doris