Coverage Report

Created: 2026-05-25 21:24

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_backend_ms_rpc_table_throttlers_scanner.h"
52
#include "information_schema/schema_catalog_meta_cache_stats_scanner.h"
53
#include "information_schema/schema_charsets_scanner.h"
54
#include "information_schema/schema_cluster_snapshot_properties_scanner.h"
55
#include "information_schema/schema_cluster_snapshots_scanner.h"
56
#include "information_schema/schema_collations_scanner.h"
57
#include "information_schema/schema_column_data_sizes_scanner.h"
58
#include "information_schema/schema_columns_scanner.h"
59
#include "information_schema/schema_compaction_tasks_scanner.h"
60
#include "information_schema/schema_database_properties_scanner.h"
61
#include "information_schema/schema_dummy_scanner.h"
62
#include "information_schema/schema_encryption_keys_scanner.h"
63
#include "information_schema/schema_file_cache_info_scanner.h"
64
#include "information_schema/schema_file_cache_statistics.h"
65
#include "information_schema/schema_files_scanner.h"
66
#include "information_schema/schema_load_job_scanner.h"
67
#include "information_schema/schema_metadata_name_ids_scanner.h"
68
#include "information_schema/schema_partitions_scanner.h"
69
#include "information_schema/schema_processlist_scanner.h"
70
#include "information_schema/schema_profiling_scanner.h"
71
#include "information_schema/schema_role_mappings_scanner.h"
72
#include "information_schema/schema_routine_load_job_scanner.h"
73
#include "information_schema/schema_rowsets_scanner.h"
74
#include "information_schema/schema_schema_privileges_scanner.h"
75
#include "information_schema/schema_schemata_scanner.h"
76
#include "information_schema/schema_sql_block_rule_status_scanner.h"
77
#include "information_schema/schema_table_options_scanner.h"
78
#include "information_schema/schema_table_privileges_scanner.h"
79
#include "information_schema/schema_table_properties_scanner.h"
80
#include "information_schema/schema_table_stream_consumption_scanner.h"
81
#include "information_schema/schema_table_streams_scanner.h"
82
#include "information_schema/schema_tables_scanner.h"
83
#include "information_schema/schema_tablets_scanner.h"
84
#include "information_schema/schema_user_privileges_scanner.h"
85
#include "information_schema/schema_user_scanner.h"
86
#include "information_schema/schema_variables_scanner.h"
87
#include "information_schema/schema_view_dependency_scanner.h"
88
#include "information_schema/schema_views_scanner.h"
89
#include "information_schema/schema_workload_group_privileges.h"
90
#include "information_schema/schema_workload_group_resource_usage_scanner.h"
91
#include "information_schema/schema_workload_groups_scanner.h"
92
#include "information_schema/schema_workload_sched_policy_scanner.h"
93
#include "runtime/fragment_mgr.h"
94
#include "util/string_util.h"
95
96
namespace doris {
97
class ObjectPool;
98
99
namespace {
100
101
void insert_column_range(ColumnWithTypeAndName* dst, const ColumnWithTypeAndName& src, size_t start,
102
0
                         size_t length) {
103
0
    DORIS_CHECK(dst->column.get() != nullptr);
104
0
    DORIS_CHECK(src.column.get() != nullptr);
105
0
    MutableColumnPtr dst_column = IColumn::mutate(std::move(dst->column));
106
0
    ColumnPtr src_column = src.column->convert_to_full_column_if_const();
107
0
    if (dst_column->is_nullable() && !src_column->is_nullable()) {
108
0
        src_column = make_nullable(src_column);
109
0
    }
110
0
    DORIS_CHECK(dst_column->is_nullable() == src_column->is_nullable());
111
0
    dst_column->insert_range_from(*src_column, start, length);
112
0
    dst->column = std::move(dst_column);
113
0
}
114
115
} // namespace
116
117
SchemaScanner::SchemaScanner(const std::vector<ColumnDesc>& columns, TSchemaTableType::type type)
118
4
        : _is_init(false), _columns(columns), _schema_table_type(type) {}
119
120
4
SchemaScanner::~SchemaScanner() = default;
121
122
0
Status SchemaScanner::start(RuntimeState* state) {
123
0
    if (!_is_init) {
124
0
        return Status::InternalError("call Start before Init.");
125
0
    }
126
127
0
    return Status::OK();
128
0
}
129
130
0
Status SchemaScanner::get_next_block(RuntimeState* state, Block* block, bool* eos) {
131
0
    if (_data_block == nullptr) {
132
0
        return Status::InternalError("No data left!");
133
0
    }
134
0
    DCHECK(_async_thread_running == false);
135
0
    RETURN_IF_ERROR(_scanner_status.status());
136
0
    for (size_t i = 0; i < block->columns(); i++) {
137
0
        insert_column_range(&block->get_by_position(i), _data_block->get_by_position(i), 0,
138
0
                            _data_block->rows());
139
0
    }
140
0
    _data_block->clear_column_data();
141
0
    *eos = _eos;
142
0
    if (!*eos) {
143
0
        RETURN_IF_ERROR(get_next_block_async(state));
144
0
    }
145
0
    return Status::OK();
146
0
}
147
148
0
Status SchemaScanner::get_next_block_async(RuntimeState* state) {
149
0
    _dependency->block();
150
0
    auto task_ctx = state->get_task_execution_context();
151
0
    RETURN_IF_ERROR(ExecEnv::GetInstance()->fragment_mgr()->get_thread_pool()->submit_func(
152
0
            [this, task_ctx, state]() {
153
0
                auto task_lock = task_ctx.lock();
154
0
                if (task_lock == nullptr) {
155
0
                    return;
156
0
                }
157
0
                DCHECK(_async_thread_running == false);
158
0
                SCOPED_ATTACH_TASK(state);
159
0
                _async_thread_running = true;
160
0
                if (!_opened) {
161
0
                    _data_block = Block::create_unique();
162
0
                    _init_block(_data_block.get());
163
0
                    _scanner_status.update(start(state));
164
0
                    _opened = true;
165
0
                }
166
0
                bool eos = false;
167
0
                auto call_next_block_internal = [&]() -> Status {
168
0
                    RETURN_IF_CATCH_EXCEPTION(
169
0
                            { return get_next_block_internal(_data_block.get(), &eos); });
170
0
                };
171
0
                _scanner_status.update(call_next_block_internal());
172
0
                _eos = eos;
173
0
                _async_thread_running = false;
174
0
                _dependency->set_ready();
175
0
            }));
176
0
    return Status::OK();
177
0
}
178
179
0
Status SchemaScanner::init(RuntimeState* state, SchemaScannerParam* param, ObjectPool* pool) {
180
0
    if (_is_init) {
181
0
        return Status::OK();
182
0
    }
183
0
    if (nullptr == param || nullptr == pool) {
184
0
        return Status::InternalError("invalid parameter");
185
0
    }
186
187
0
    _param = param;
188
0
    _timezone = state->timezone();
189
0
    _timezone_obj = state->timezone_obj();
190
0
    _is_init = true;
191
192
0
    if (_param->profile) {
193
0
        _get_db_timer = ADD_TIMER(_param->profile, "GetDbTime");
194
0
        _get_table_timer = ADD_TIMER(_param->profile, "GetTableTime");
195
0
        _get_describe_timer = ADD_TIMER(_param->profile, "GetDescribeTime");
196
0
        _fill_block_timer = ADD_TIMER(_param->profile, "FillBlockTime");
197
0
    }
198
199
0
    return Status::OK();
200
0
}
201
202
1
std::unique_ptr<SchemaScanner> SchemaScanner::create(TSchemaTableType::type type) {
203
1
    switch (type) {
204
0
    case TSchemaTableType::SCH_TABLES:
205
0
        return SchemaTablesScanner::create_unique();
206
0
    case TSchemaTableType::SCH_SCHEMATA:
207
0
        return SchemaSchemataScanner::create_unique();
208
0
    case TSchemaTableType::SCH_COLUMNS:
209
0
        return SchemaColumnsScanner::create_unique();
210
0
    case TSchemaTableType::SCH_CHARSETS:
211
0
        return SchemaCharsetsScanner::create_unique();
212
0
    case TSchemaTableType::SCH_COLLATIONS:
213
0
        return SchemaCollationsScanner::create_unique();
214
0
    case TSchemaTableType::SCH_GLOBAL_VARIABLES:
215
0
        return SchemaVariablesScanner::create_unique(TVarType::GLOBAL);
216
0
    case TSchemaTableType::SCH_SESSION_VARIABLES:
217
0
    case TSchemaTableType::SCH_VARIABLES:
218
0
        return SchemaVariablesScanner::create_unique(TVarType::SESSION);
219
0
    case TSchemaTableType::SCH_VIEWS:
220
0
        return SchemaViewsScanner::create_unique();
221
0
    case TSchemaTableType::SCH_TABLE_PRIVILEGES:
222
0
        return SchemaTablePrivilegesScanner::create_unique();
223
0
    case TSchemaTableType::SCH_SCHEMA_PRIVILEGES:
224
0
        return SchemaSchemaPrivilegesScanner::create_unique();
225
0
    case TSchemaTableType::SCH_USER_PRIVILEGES:
226
0
        return SchemaUserPrivilegesScanner::create_unique();
227
0
    case TSchemaTableType::SCH_FILES:
228
0
        return SchemaFilesScanner::create_unique();
229
0
    case TSchemaTableType::SCH_PARTITIONS:
230
0
        return SchemaPartitionsScanner::create_unique();
231
0
    case TSchemaTableType::SCH_BACKEND_CONFIGURATION:
232
0
        return SchemaBackendConfigurationScanner::create_unique();
233
0
    case TSchemaTableType::SCH_ROWSETS:
234
0
        return SchemaRowsetsScanner::create_unique();
235
0
    case TSchemaTableType::SCH_METADATA_NAME_IDS:
236
0
        return SchemaMetadataNameIdsScanner::create_unique();
237
0
    case TSchemaTableType::SCH_PROFILING:
238
0
        return SchemaProfilingScanner::create_unique();
239
0
    case TSchemaTableType::SCH_BACKEND_ACTIVE_TASKS:
240
0
        return SchemaBackendActiveTasksScanner::create_unique();
241
0
    case TSchemaTableType::SCH_ACTIVE_QUERIES:
242
0
        return SchemaActiveQueriesScanner::create_unique();
243
0
    case TSchemaTableType::SCH_WORKLOAD_GROUPS:
244
0
        return SchemaWorkloadGroupsScanner::create_unique();
245
0
    case TSchemaTableType::SCH_PROCESSLIST:
246
0
        return SchemaProcessListScanner::create_unique();
247
0
    case TSchemaTableType::SCH_USER:
248
0
        return SchemaUserScanner::create_unique();
249
0
    case TSchemaTableType::SCH_WORKLOAD_POLICY:
250
0
        return SchemaWorkloadSchedulePolicyScanner::create_unique();
251
0
    case TSchemaTableType::SCH_TABLE_OPTIONS:
252
0
        return SchemaTableOptionsScanner::create_unique();
253
0
    case TSchemaTableType::SCH_WORKLOAD_GROUP_PRIVILEGES:
254
0
        return SchemaWorkloadGroupPrivilegesScanner::create_unique();
255
0
    case TSchemaTableType::SCH_WORKLOAD_GROUP_RESOURCE_USAGE:
256
0
        return SchemaBackendWorkloadGroupResourceUsage::create_unique();
257
0
    case TSchemaTableType::SCH_TABLE_PROPERTIES:
258
0
        return SchemaTablePropertiesScanner::create_unique();
259
0
    case TSchemaTableType::SCH_DATABASE_PROPERTIES:
260
0
        return SchemaDatabasePropertiesScanner::create_unique();
261
0
    case TSchemaTableType::SCH_FILE_CACHE_STATISTICS:
262
0
        return SchemaFileCacheStatisticsScanner::create_unique();
263
0
    case TSchemaTableType::SCH_CATALOG_META_CACHE_STATISTICS:
264
0
        return SchemaCatalogMetaCacheStatsScanner::create_unique();
265
0
    case TSchemaTableType::SCH_BACKEND_KERBEROS_TICKET_CACHE:
266
0
        return SchemaBackendKerberosTicketCacheScanner::create_unique();
267
0
    case TSchemaTableType::SCH_ROUTINE_LOAD_JOBS:
268
0
        return SchemaRoutineLoadJobScanner::create_unique();
269
0
    case TSchemaTableType::SCH_LOAD_JOBS:
270
0
        return SchemaLoadJobScanner::create_unique();
271
0
    case TSchemaTableType::SCH_BACKEND_TABLETS:
272
0
        return SchemaTabletsScanner::create_unique();
273
0
    case TSchemaTableType::SCH_VIEW_DEPENDENCY:
274
0
        return SchemaViewDependencyScanner::create_unique();
275
0
    case TSchemaTableType::SCH_SQL_BLOCK_RULE_STATUS:
276
0
        return SchemaSqlBlockRuleStatusScanner::create_unique();
277
0
    case TSchemaTableType::SCH_ENCRYPTION_KEYS:
278
0
        return SchemaEncryptionKeysScanner::create_unique();
279
0
    case TSchemaTableType::SCH_CLUSTER_SNAPSHOTS:
280
0
        return SchemaClusterSnapshotsScanner::create_unique();
281
0
    case TSchemaTableType::SCH_CLUSTER_SNAPSHOT_PROPERTIES:
282
0
        return SchemaClusterSnapshotPropertiesScanner::create_unique();
283
0
    case TSchemaTableType::SCH_COLUMN_DATA_SIZES:
284
0
        return SchemaColumnDataSizesScanner::create_unique();
285
0
    case TSchemaTableType::SCH_FILE_CACHE_INFO:
286
0
        return SchemaFileCacheInfoScanner::create_unique();
287
0
    case TSchemaTableType::SCH_AUTHENTICATION_INTEGRATIONS:
288
0
        return SchemaAuthenticationIntegrationsScanner::create_unique();
289
1
    case TSchemaTableType::SCH_ROLE_MAPPINGS:
290
1
        return SchemaRoleMappingsScanner::create_unique();
291
0
    case TSchemaTableType::SCH_TABLE_STREAMS:
292
0
        return SchemaTableStreamsScanner::create_unique();
293
0
    case TSchemaTableType::SCH_TABLE_STREAM_CONSUMPTION:
294
0
        return SchemaTableStreamConsumptionScanner::create_unique();
295
0
    case TSchemaTableType::SCH_BE_COMPACTION_TASKS:
296
0
        return SchemaCompactionTasksScanner::create_unique();
297
0
    case TSchemaTableType::SCH_BACKEND_MS_RPC_TABLE_THROTTLERS:
298
0
        return SchemaBackendMsRpcTableThrottlersScanner::create_unique();
299
0
    default:
300
0
        return SchemaDummyScanner::create_unique();
301
0
        break;
302
1
    }
303
1
}
304
305
3
void SchemaScanner::_init_block(Block* src_block) {
306
3
    const std::vector<SchemaScanner::ColumnDesc>& columns_desc(get_column_desc());
307
31
    for (int i = 0; i < columns_desc.size(); ++i) {
308
28
        auto data_type = DataTypeFactory::instance().create_data_type(columns_desc[i].type, true);
309
28
        src_block->insert(
310
28
                ColumnWithTypeAndName(data_type->create_column(), data_type, columns_desc[i].name));
311
28
    }
312
3
}
313
314
Status SchemaScanner::fill_dest_column_for_range(Block* block, size_t pos,
315
24
                                                 const std::vector<void*>& datas) {
316
24
    const ColumnDesc& col_desc = _columns[pos];
317
24
    MutableColumnPtr column_ptr = IColumn::mutate(std::move(block->get_by_position(pos).column));
318
24
    IColumn* col_ptr = column_ptr.get();
319
320
24
    auto* nullable_column = assert_cast<ColumnNullable*>(col_ptr);
321
322
    // Resize in advance to improve insertion efficiency.
323
24
    size_t fill_num = datas.size();
324
24
    col_ptr = &nullable_column->get_nested_column();
325
61
    for (int i = 0; i < fill_num; ++i) {
326
37
        auto* data = datas[i];
327
37
        if (data == nullptr) {
328
            // For nested column need not insert default.
329
12
            nullable_column->insert_data(nullptr, 0);
330
12
            continue;
331
25
        } else {
332
25
            nullable_column->push_false_to_nullmap(1);
333
25
        }
334
25
        switch (col_desc.type) {
335
0
        case TYPE_HLL: {
336
0
            auto* hll_slot = reinterpret_cast<HyperLogLog*>(data);
337
0
            assert_cast<ColumnHLL*>(col_ptr)->get_data().emplace_back(*hll_slot);
338
0
            break;
339
0
        }
340
0
        case TYPE_VARCHAR:
341
0
        case TYPE_CHAR:
342
13
        case TYPE_STRING: {
343
13
            auto* str_slot = reinterpret_cast<StringRef*>(data);
344
13
            assert_cast<ColumnString*>(col_ptr)->insert_data(str_slot->data, str_slot->size);
345
13
            break;
346
0
        }
347
348
1
        case TYPE_BOOLEAN: {
349
1
            uint8_t num = *reinterpret_cast<bool*>(data);
350
1
            assert_cast<ColumnBool*>(col_ptr)->insert_value(num);
351
1
            break;
352
0
        }
353
354
0
        case TYPE_TINYINT: {
355
0
            int8_t num = *reinterpret_cast<int8_t*>(data);
356
0
            assert_cast<ColumnInt8*>(col_ptr)->insert_value(num);
357
0
            break;
358
0
        }
359
360
0
        case TYPE_SMALLINT: {
361
0
            int16_t num = *reinterpret_cast<int16_t*>(data);
362
0
            assert_cast<ColumnInt16*>(col_ptr)->insert_value(num);
363
0
            break;
364
0
        }
365
366
4
        case TYPE_INT: {
367
4
            int32_t num = *reinterpret_cast<int32_t*>(data);
368
4
            assert_cast<ColumnInt32*>(col_ptr)->insert_value(num);
369
4
            break;
370
0
        }
371
372
3
        case TYPE_BIGINT: {
373
3
            int64_t num = *reinterpret_cast<int64_t*>(data);
374
3
            assert_cast<ColumnInt64*>(col_ptr)->insert_value(num);
375
3
            break;
376
0
        }
377
378
0
        case TYPE_LARGEINT: {
379
0
            __int128 num;
380
0
            memcpy(&num, data, sizeof(__int128));
381
0
            assert_cast<ColumnInt128*>(col_ptr)->insert_value(num);
382
0
            break;
383
0
        }
384
385
0
        case TYPE_FLOAT: {
386
0
            float num = *reinterpret_cast<float*>(data);
387
0
            assert_cast<ColumnFloat32*>(col_ptr)->insert_value(num);
388
0
            break;
389
0
        }
390
391
0
        case TYPE_DOUBLE: {
392
0
            double num = *reinterpret_cast<double*>(data);
393
0
            assert_cast<ColumnFloat64*>(col_ptr)->insert_value(num);
394
0
            break;
395
0
        }
396
397
0
        case TYPE_DATE: {
398
0
            assert_cast<ColumnDate*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
399
0
            break;
400
0
        }
401
402
0
        case TYPE_DATEV2: {
403
0
            assert_cast<ColumnDateV2*>(col_ptr)->insert_value(
404
0
                    *reinterpret_cast<DateV2Value<DateV2ValueType>*>(data));
405
0
            break;
406
0
        }
407
408
0
        case TYPE_DATETIME: {
409
0
            assert_cast<ColumnDateTime*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
410
0
            break;
411
0
        }
412
413
4
        case TYPE_DATETIMEV2: {
414
4
            assert_cast<ColumnDateTimeV2*>(col_ptr)->insert_value(
415
4
                    *reinterpret_cast<DateV2Value<DateTimeV2ValueType>*>(data));
416
4
            break;
417
0
        }
418
419
0
        case TYPE_TIMESTAMPTZ: {
420
0
            assert_cast<ColumnTimeStampTz*>(col_ptr)->insert_value(
421
0
                    *reinterpret_cast<TimestampTzValue*>(data));
422
0
            break;
423
0
        }
424
425
0
        case TYPE_DECIMALV2: {
426
0
            const Int128 num = (reinterpret_cast<PackedInt128*>(data))->value;
427
0
            assert_cast<ColumnDecimal128V2*>(col_ptr)->insert_data(
428
0
                    reinterpret_cast<const char*>(&num), 0);
429
0
            break;
430
0
        }
431
0
        case TYPE_DECIMAL128I: {
432
0
            const Int128 num = (reinterpret_cast<PackedInt128*>(data))->value;
433
0
            assert_cast<ColumnDecimal128V3*>(col_ptr)->insert_data(
434
0
                    reinterpret_cast<const char*>(&num), 0);
435
0
            break;
436
0
        }
437
438
0
        case TYPE_DECIMAL32: {
439
0
            const int32_t num = *reinterpret_cast<int32_t*>(data);
440
0
            assert_cast<ColumnDecimal32*>(col_ptr)->insert_data(reinterpret_cast<const char*>(&num),
441
0
                                                                0);
442
0
            break;
443
0
        }
444
445
0
        case TYPE_DECIMAL64: {
446
0
            const int64_t num = *reinterpret_cast<int64_t*>(data);
447
0
            assert_cast<ColumnDecimal64*>(col_ptr)->insert_data(reinterpret_cast<const char*>(&num),
448
0
                                                                0);
449
0
            break;
450
0
        }
451
452
0
        default: {
453
0
            DCHECK(false) << "bad slot type: " << col_desc.type;
454
0
            std::stringstream ss;
455
0
            ss << "Fail to convert schema type:'" << col_desc.type << " on column:`"
456
0
               << std::string(col_desc.name) + "`";
457
0
            return Status::InternalError(ss.str());
458
0
        }
459
25
        }
460
25
    }
461
24
    block->replace_by_position(pos, std::move(column_ptr));
462
24
    return Status::OK();
463
24
}
464
465
0
std::string SchemaScanner::get_db_from_full_name(const std::string& full_name) {
466
0
    std::vector<std::string> part = split(full_name, ".");
467
0
    if (part.size() == 2) {
468
0
        return part[1];
469
0
    }
470
0
    return full_name;
471
0
}
472
473
Status SchemaScanner::insert_block_column(TCell cell, int col_index, Block* block,
474
0
                                          PrimitiveType type) {
475
0
    MutableColumnPtr mutable_col_ptr;
476
0
    mutable_col_ptr = IColumn::mutate(std::move(block->get_by_position(col_index).column));
477
0
    auto* nullable_column = assert_cast<ColumnNullable*>(mutable_col_ptr.get());
478
0
    IColumn* col_ptr = &nullable_column->get_nested_column();
479
480
0
    switch (type) {
481
0
    case TYPE_BIGINT: {
482
0
        reinterpret_cast<ColumnInt64*>(col_ptr)->insert_value(cell.longVal);
483
0
        break;
484
0
    }
485
486
0
    case TYPE_INT: {
487
0
        reinterpret_cast<ColumnInt32*>(col_ptr)->insert_value(cell.intVal);
488
0
        break;
489
0
    }
490
491
0
    case TYPE_FLOAT: {
492
0
        assert_cast<ColumnFloat32*>(col_ptr)->insert_value(cell.doubleVal);
493
0
        break;
494
0
    }
495
496
0
    case TYPE_DOUBLE: {
497
0
        assert_cast<ColumnFloat64*>(col_ptr)->insert_value(cell.doubleVal);
498
0
        break;
499
0
    }
500
501
0
    case TYPE_BOOLEAN: {
502
0
        reinterpret_cast<ColumnUInt8*>(col_ptr)->insert_value(cell.boolVal);
503
0
        break;
504
0
    }
505
506
0
    case TYPE_STRING:
507
0
    case TYPE_VARCHAR:
508
0
    case TYPE_CHAR: {
509
0
        reinterpret_cast<ColumnString*>(col_ptr)->insert_data(cell.stringVal.data(),
510
0
                                                              cell.stringVal.size());
511
0
        break;
512
0
    }
513
514
0
    case TYPE_DATETIME: {
515
0
        std::vector<void*> datas(1);
516
0
        VecDateTimeValue src[1];
517
0
        CastParameters params;
518
0
        CastToDateOrDatetime::from_string_non_strict_mode<DatelikeTargetType::DATE_TIME>(
519
0
                {cell.stringVal.data(), cell.stringVal.size()}, src[0], nullptr, params);
520
0
        datas[0] = src;
521
0
        auto data = datas[0];
522
0
        reinterpret_cast<ColumnDateTime*>(col_ptr)->insert_data(reinterpret_cast<char*>(data), 0);
523
0
        break;
524
0
    }
525
0
    default: {
526
0
        std::stringstream ss;
527
0
        ss << "unsupported column type:" << type;
528
0
        return Status::InternalError(ss.str());
529
0
    }
530
0
    }
531
0
    nullable_column->push_false_to_nullmap(1);
532
0
    block->replace_by_position(col_index, std::move(mutable_col_ptr));
533
0
    return Status::OK();
534
0
}
535
536
} // namespace doris