Coverage Report

Created: 2026-05-22 05:25

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exec/scan/meta_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 "exec/scan/meta_scanner.h"
19
20
#include <fmt/format.h>
21
#include <gen_cpp/FrontendService.h>
22
#include <gen_cpp/FrontendService_types.h>
23
#include <gen_cpp/HeartbeatService_types.h>
24
#include <gen_cpp/PaloInternalService_types.h>
25
#include <gen_cpp/PlanNodes_types.h>
26
27
#include <ostream>
28
#include <string>
29
#include <unordered_map>
30
31
#include "common/cast_set.h"
32
#include "common/logging.h"
33
#include "core/block/block.h"
34
#include "core/column/column.h"
35
#include "core/column/column_nullable.h"
36
#include "core/column/column_string.h"
37
#include "core/column/column_vector.h"
38
#include "core/data_type/define_primitive_type.h"
39
#include "core/types.h"
40
#include "format/table/parquet_metadata_reader.h"
41
#include "runtime/descriptors.h"
42
#include "runtime/exec_env.h"
43
#include "runtime/runtime_state.h"
44
#include "util/client_cache.h"
45
#include "util/thrift_rpc_helper.h"
46
47
namespace doris {
48
class RuntimeProfile;
49
class VExprContext;
50
} // namespace doris
51
52
namespace doris {
53
54
MetaScanner::MetaScanner(RuntimeState* state, ScanLocalStateBase* local_state, TupleId tuple_id,
55
                         const TScanRangeParams& scan_range, int64_t limit, RuntimeProfile* profile,
56
                         TUserIdentity user_identity)
57
5.59k
        : Scanner(state, local_state, limit, profile),
58
5.59k
          _meta_eos(false),
59
5.59k
          _tuple_id(tuple_id),
60
5.59k
          _user_identity(user_identity),
61
5.59k
          _scan_range(scan_range.scan_range) {}
62
63
5.59k
Status MetaScanner::_open_impl(RuntimeState* state) {
64
5.59k
    VLOG_CRITICAL << "MetaScanner::open";
65
5.59k
    RETURN_IF_ERROR(Scanner::_open_impl(state));
66
5.59k
    if (_scan_range.meta_scan_range.metadata_type == TMetadataType::PARQUET) {
67
38
        auto reader = ParquetMetadataReader::create_unique(_tuple_desc->slots(), state, _profile,
68
38
                                                           _scan_range.meta_scan_range);
69
38
        RETURN_IF_ERROR(reader->init_reader());
70
38
        _reader = std::move(reader);
71
5.55k
    } else {
72
5.55k
        RETURN_IF_ERROR(_fetch_metadata(_scan_range.meta_scan_range));
73
5.55k
    }
74
5.59k
    return Status::OK();
75
5.59k
}
76
77
5.58k
Status MetaScanner::init(RuntimeState* state, const VExprContextSPtrs& conjuncts) {
78
18.4E
    VLOG_CRITICAL << "MetaScanner::init";
79
5.58k
    RETURN_IF_ERROR(Scanner::init(_state, conjuncts));
80
5.58k
    _tuple_desc = state->desc_tbl().get_tuple_descriptor(_tuple_id);
81
5.58k
    return Status::OK();
82
5.58k
}
83
84
10.3k
Status MetaScanner::_get_block_impl(RuntimeState* state, Block* block, bool* eof) {
85
10.3k
    VLOG_CRITICAL << "MetaScanner::_get_block_impl";
86
10.3k
    if (nullptr == state || nullptr == block || nullptr == eof) {
87
0
        return Status::InternalError("input is NULL pointer");
88
0
    }
89
90
    // Build name to index map only once on first call
91
10.3k
    if (_src_block_name_to_idx.empty()) {
92
5.59k
        _src_block_name_to_idx = block->get_name_to_pos_map();
93
5.59k
    }
94
95
10.3k
    if (_reader) {
96
        // TODO: This is a temporary workaround; the code is planned to be refactored later.
97
73
        size_t read_rows = 0;
98
73
        return _reader->get_next_block(block, &read_rows, eof);
99
73
    }
100
101
10.2k
    if (_meta_eos == true) {
102
4.70k
        *eof = true;
103
4.70k
        return Status::OK();
104
4.70k
    }
105
106
5.55k
    auto column_size = _tuple_desc->slots().size();
107
5.55k
    std::vector<MutableColumnPtr> columns(column_size);
108
5.55k
    bool mem_reuse = block->mem_reuse();
109
5.55k
    do {
110
5.55k
        RETURN_IF_CANCELLED(state);
111
112
5.55k
        columns.resize(column_size);
113
35.3k
        for (auto i = 0; i < column_size; i++) {
114
29.8k
            if (mem_reuse) {
115
29.8k
                columns[i] = block->get_by_position(i).column->assume_mutable();
116
29.8k
            } else {
117
0
                columns[i] = _tuple_desc->slots()[i]->get_empty_mutable_column();
118
0
            }
119
29.8k
        }
120
        // fill block
121
5.55k
        RETURN_IF_ERROR(_fill_block_with_remote_data(columns));
122
5.55k
        if (_meta_eos == true) {
123
5.55k
            if (block->rows() == 0) {
124
837
                *eof = true;
125
837
            }
126
5.55k
            break;
127
5.55k
        }
128
        // Before really use the Block, must clear other ptr of column in block
129
        // So here need do std::move and clear in `columns`
130
18.4E
        if (!mem_reuse) {
131
0
            int column_index = 0;
132
0
            for (const auto slot_desc : _tuple_desc->slots()) {
133
0
                block->insert(ColumnWithTypeAndName(std::move(columns[column_index++]),
134
0
                                                    slot_desc->get_data_type_ptr(),
135
0
                                                    slot_desc->col_name()));
136
0
            }
137
18.4E
        } else {
138
18.4E
            columns.clear();
139
18.4E
        }
140
18.4E
        VLOG_ROW << "VMetaScanNode output rows: " << block->rows();
141
18.4E
    } while (block->rows() == 0 && !(*eof));
142
5.55k
    return Status::OK();
143
5.55k
}
144
145
5.55k
Status MetaScanner::_fill_block_with_remote_data(const std::vector<MutableColumnPtr>& columns) {
146
5.55k
    VLOG_CRITICAL << "MetaScanner::_fill_block_with_remote_data";
147
34.3k
    for (int col_idx = 0; col_idx < columns.size(); col_idx++) {
148
29.8k
        auto slot_desc = _tuple_desc->slots()[col_idx];
149
150
3.17M
        for (int _row_idx = 0; _row_idx < _batch_data.size(); _row_idx++) {
151
3.14M
            IColumn* col_ptr = columns[col_idx].get();
152
3.14M
            TCell& cell = _batch_data[_row_idx].column_value[col_idx];
153
3.14M
            if (cell.__isset.isNull && cell.isNull) {
154
41
                DCHECK(slot_desc->is_nullable())
155
0
                        << "cell is null but column is not nullable: " << slot_desc->col_name();
156
41
                auto& null_col = reinterpret_cast<ColumnNullable&>(*col_ptr);
157
41
                null_col.get_nested_column().insert_default();
158
41
                null_col.get_null_map_data().push_back(1);
159
3.14M
            } else {
160
3.14M
                if (slot_desc->is_nullable()) {
161
115
                    auto& null_col = reinterpret_cast<ColumnNullable&>(*col_ptr);
162
115
                    null_col.get_null_map_data().push_back(0);
163
115
                    col_ptr = null_col.get_nested_column_ptr().get();
164
115
                }
165
3.14M
                switch (slot_desc->type()->get_primitive_type()) {
166
5.50k
                case TYPE_BOOLEAN: {
167
5.50k
                    bool data = cell.boolVal;
168
5.50k
                    assert_cast<ColumnBool*>(col_ptr)->insert_value((uint8_t)data);
169
5.50k
                    break;
170
0
                }
171
2
                case TYPE_TINYINT: {
172
2
                    int8_t data = (int8_t)cell.intVal;
173
2
                    assert_cast<ColumnInt8*>(col_ptr)->insert_value(data);
174
2
                    break;
175
0
                }
176
2
                case TYPE_SMALLINT: {
177
2
                    int16_t data = (int16_t)cell.intVal;
178
2
                    assert_cast<ColumnInt16*>(col_ptr)->insert_value(data);
179
2
                    break;
180
0
                }
181
101
                case TYPE_INT: {
182
101
                    int32_t data = cell.intVal;
183
101
                    assert_cast<ColumnInt32*>(col_ptr)->insert_value(data);
184
101
                    break;
185
0
                }
186
3.51k
                case TYPE_BIGINT: {
187
3.51k
                    int64_t data = cell.longVal;
188
3.51k
                    assert_cast<ColumnInt64*>(col_ptr)->insert_value(data);
189
3.51k
                    break;
190
0
                }
191
39
                case TYPE_FLOAT: {
192
39
                    auto data = static_cast<float>(cell.doubleVal);
193
39
                    assert_cast<ColumnFloat32*>(col_ptr)->insert_value(data);
194
39
                    break;
195
0
                }
196
15
                case TYPE_DOUBLE: {
197
15
                    double data = cell.doubleVal;
198
15
                    assert_cast<ColumnFloat64*>(col_ptr)->insert_value(data);
199
15
                    break;
200
0
                }
201
2
                case TYPE_DATEV2: {
202
2
                    uint32_t data = (uint32_t)cell.longVal;
203
2
                    assert_cast<ColumnDateV2*>(col_ptr)->insert_value(data);
204
2
                    break;
205
0
                }
206
2
                case TYPE_DATETIMEV2: {
207
2
                    uint64_t data = cell.longVal;
208
2
                    assert_cast<ColumnDateTimeV2*>(col_ptr)->insert_value(data);
209
2
                    break;
210
0
                }
211
3.13M
                case TYPE_STRING:
212
3.13M
                case TYPE_CHAR:
213
3.13M
                case TYPE_VARCHAR: {
214
3.13M
                    std::string data = cell.stringVal;
215
3.13M
                    assert_cast<ColumnString*>(col_ptr)->insert_data(data.c_str(), data.length());
216
3.13M
                    break;
217
3.13M
                }
218
0
                default: {
219
0
                    std::string error_msg =
220
0
                            fmt::format("Invalid column type {} on column: {}.",
221
0
                                        slot_desc->type()->get_name(), slot_desc->col_name());
222
0
                    return Status::InternalError(std::string(error_msg));
223
3.13M
                }
224
3.14M
                }
225
3.14M
            }
226
3.14M
        }
227
29.8k
    }
228
4.51k
    _meta_eos = true;
229
4.51k
    return Status::OK();
230
5.55k
}
231
232
5.55k
Status MetaScanner::_fetch_metadata(const TMetaScanRange& meta_scan_range) {
233
5.55k
    VLOG_CRITICAL << "MetaScanner::_fetch_metadata";
234
5.55k
    TFetchSchemaTableDataRequest request;
235
5.55k
    switch (meta_scan_range.metadata_type) {
236
0
    case TMetadataType::HUDI:
237
0
        RETURN_IF_ERROR(_build_hudi_metadata_request(meta_scan_range, &request));
238
0
        break;
239
15
    case TMetadataType::BACKENDS:
240
15
        RETURN_IF_ERROR(_build_backends_metadata_request(meta_scan_range, &request));
241
15
        break;
242
37
    case TMetadataType::FRONTENDS:
243
37
        RETURN_IF_ERROR(_build_frontends_metadata_request(meta_scan_range, &request));
244
37
        break;
245
37
    case TMetadataType::FRONTENDS_DISKS:
246
7
        RETURN_IF_ERROR(_build_frontends_disks_metadata_request(meta_scan_range, &request));
247
7
        break;
248
7
    case TMetadataType::WORKLOAD_SCHED_POLICY:
249
0
        RETURN_IF_ERROR(_build_workload_sched_policy_metadata_request(meta_scan_range, &request));
250
0
        break;
251
25
    case TMetadataType::CATALOGS:
252
25
        RETURN_IF_ERROR(_build_catalogs_metadata_request(meta_scan_range, &request));
253
25
        break;
254
2.21k
    case TMetadataType::MATERIALIZED_VIEWS:
255
2.21k
        RETURN_IF_ERROR(_build_materialized_views_metadata_request(meta_scan_range, &request));
256
2.21k
        break;
257
2.21k
    case TMetadataType::PARTITIONS:
258
22
        RETURN_IF_ERROR(_build_partitions_metadata_request(meta_scan_range, &request));
259
22
        break;
260
936
    case TMetadataType::JOBS:
261
936
        RETURN_IF_ERROR(_build_jobs_metadata_request(meta_scan_range, &request));
262
936
        break;
263
2.28k
    case TMetadataType::TASKS:
264
2.28k
        RETURN_IF_ERROR(_build_tasks_metadata_request(meta_scan_range, &request));
265
2.28k
        break;
266
2.28k
    case TMetadataType::PARTITION_VALUES:
267
20
        RETURN_IF_ERROR(_build_partition_values_metadata_request(meta_scan_range, &request));
268
20
        break;
269
20
    default:
270
0
        _meta_eos = true;
271
0
        return Status::OK();
272
5.55k
    }
273
274
    // set filter columns
275
5.55k
    std::vector<std::string> filter_columns;
276
29.8k
    for (const auto& slot : _tuple_desc->slots()) {
277
29.8k
        filter_columns.emplace_back(slot->col_name_lower_case());
278
29.8k
    }
279
5.55k
    request.metada_table_params.__set_columns_name(filter_columns);
280
281
    // _state->execution_timeout() is seconds, change to milliseconds
282
5.55k
    int time_out = _state->execution_timeout() * 1000;
283
5.55k
    TNetworkAddress master_addr = ExecEnv::GetInstance()->cluster_info()->master_fe_addr;
284
5.55k
    TFetchSchemaTableDataResult result;
285
5.55k
    RETURN_IF_ERROR(ThriftRpcHelper::rpc<FrontendServiceClient>(
286
5.55k
            master_addr.hostname, master_addr.port,
287
5.55k
            [&request, &result](FrontendServiceConnection& client) {
288
5.55k
                client->fetchSchemaTableData(result, request);
289
5.55k
            },
290
5.55k
            time_out));
291
292
5.55k
    Status status(Status::create(result.status));
293
5.55k
    if (!status.ok()) {
294
0
        LOG(WARNING) << "fetch schema table data from master failed, errmsg=" << status;
295
0
        return status;
296
0
    }
297
5.55k
    _batch_data = std::move(result.data_batch);
298
5.55k
    return Status::OK();
299
5.55k
}
300
301
Status MetaScanner::_build_hudi_metadata_request(const TMetaScanRange& meta_scan_range,
302
0
                                                 TFetchSchemaTableDataRequest* request) {
303
0
    VLOG_CRITICAL << "MetaScanner::_build_hudi_metadata_request";
304
0
    if (!meta_scan_range.__isset.hudi_params) {
305
0
        return Status::InternalError("Can not find THudiMetadataParams from meta_scan_range.");
306
0
    }
307
308
    // create request
309
0
    request->__set_cluster_name("");
310
0
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
311
312
    // create TMetadataTableRequestParams
313
0
    TMetadataTableRequestParams metadata_table_params;
314
0
    metadata_table_params.__set_metadata_type(TMetadataType::HUDI);
315
0
    metadata_table_params.__set_hudi_metadata_params(meta_scan_range.hudi_params);
316
317
0
    request->__set_metada_table_params(metadata_table_params);
318
0
    return Status::OK();
319
0
}
320
321
Status MetaScanner::_build_backends_metadata_request(const TMetaScanRange& meta_scan_range,
322
15
                                                     TFetchSchemaTableDataRequest* request) {
323
15
    VLOG_CRITICAL << "MetaScanner::_build_backends_metadata_request";
324
15
    if (!meta_scan_range.__isset.backends_params) {
325
0
        return Status::InternalError("Can not find TBackendsMetadataParams from meta_scan_range.");
326
0
    }
327
    // create request
328
15
    request->__set_cluster_name("");
329
15
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
330
331
    // create TMetadataTableRequestParams
332
15
    TMetadataTableRequestParams metadata_table_params;
333
15
    metadata_table_params.__set_metadata_type(TMetadataType::BACKENDS);
334
15
    metadata_table_params.__set_backends_metadata_params(meta_scan_range.backends_params);
335
336
15
    request->__set_metada_table_params(metadata_table_params);
337
15
    return Status::OK();
338
15
}
339
340
Status MetaScanner::_build_frontends_metadata_request(const TMetaScanRange& meta_scan_range,
341
37
                                                      TFetchSchemaTableDataRequest* request) {
342
37
    VLOG_CRITICAL << "MetaScanner::_build_frontends_metadata_request";
343
37
    if (!meta_scan_range.__isset.frontends_params) {
344
0
        return Status::InternalError("Can not find TFrontendsMetadataParams from meta_scan_range.");
345
0
    }
346
    // create request
347
37
    request->__set_cluster_name("");
348
37
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
349
350
    // create TMetadataTableRequestParams
351
37
    TMetadataTableRequestParams metadata_table_params;
352
37
    metadata_table_params.__set_metadata_type(TMetadataType::FRONTENDS);
353
37
    metadata_table_params.__set_frontends_metadata_params(meta_scan_range.frontends_params);
354
355
37
    request->__set_metada_table_params(metadata_table_params);
356
37
    return Status::OK();
357
37
}
358
359
Status MetaScanner::_build_frontends_disks_metadata_request(const TMetaScanRange& meta_scan_range,
360
7
                                                            TFetchSchemaTableDataRequest* request) {
361
7
    VLOG_CRITICAL << "MetaScanner::_build_frontends_metadata_request";
362
7
    if (!meta_scan_range.__isset.frontends_params) {
363
0
        return Status::InternalError("Can not find TFrontendsMetadataParams from meta_scan_range.");
364
0
    }
365
    // create request
366
7
    request->__set_cluster_name("");
367
7
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
368
369
    // create TMetadataTableRequestParams
370
7
    TMetadataTableRequestParams metadata_table_params;
371
7
    metadata_table_params.__set_metadata_type(TMetadataType::FRONTENDS_DISKS);
372
7
    metadata_table_params.__set_frontends_metadata_params(meta_scan_range.frontends_params);
373
374
7
    request->__set_metada_table_params(metadata_table_params);
375
7
    return Status::OK();
376
7
}
377
378
Status MetaScanner::_build_workload_sched_policy_metadata_request(
379
0
        const TMetaScanRange& meta_scan_range, TFetchSchemaTableDataRequest* request) {
380
0
    VLOG_CRITICAL << "MetaScanner::_build_workload_sched_policy_metadata_request";
381
382
    // create request
383
0
    request->__set_cluster_name("");
384
0
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
385
386
    // create TMetadataTableRequestParams
387
0
    TMetadataTableRequestParams metadata_table_params;
388
0
    metadata_table_params.__set_metadata_type(TMetadataType::WORKLOAD_SCHED_POLICY);
389
0
    metadata_table_params.__set_current_user_ident(_user_identity);
390
391
0
    request->__set_metada_table_params(metadata_table_params);
392
0
    return Status::OK();
393
0
}
394
395
Status MetaScanner::_build_catalogs_metadata_request(const TMetaScanRange& meta_scan_range,
396
25
                                                     TFetchSchemaTableDataRequest* request) {
397
25
    VLOG_CRITICAL << "MetaScanner::_build_catalogs_metadata_request";
398
399
    // create request
400
25
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
401
402
    // create TMetadataTableRequestParams
403
25
    TMetadataTableRequestParams metadata_table_params;
404
25
    metadata_table_params.__set_metadata_type(TMetadataType::CATALOGS);
405
25
    metadata_table_params.__set_current_user_ident(_user_identity);
406
407
25
    request->__set_metada_table_params(metadata_table_params);
408
25
    return Status::OK();
409
25
}
410
411
Status MetaScanner::_build_materialized_views_metadata_request(
412
2.21k
        const TMetaScanRange& meta_scan_range, TFetchSchemaTableDataRequest* request) {
413
2.21k
    VLOG_CRITICAL << "MetaScanner::_build_materialized_views_metadata_request";
414
2.21k
    if (!meta_scan_range.__isset.materialized_views_params) {
415
0
        return Status::InternalError(
416
0
                "Can not find TMaterializedViewsMetadataParams from meta_scan_range.");
417
0
    }
418
419
    // create request
420
2.21k
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
421
422
    // create TMetadataTableRequestParams
423
2.21k
    TMetadataTableRequestParams metadata_table_params;
424
2.21k
    metadata_table_params.__set_metadata_type(TMetadataType::MATERIALIZED_VIEWS);
425
2.21k
    metadata_table_params.__set_materialized_views_metadata_params(
426
2.21k
            meta_scan_range.materialized_views_params);
427
428
2.21k
    request->__set_metada_table_params(metadata_table_params);
429
2.21k
    return Status::OK();
430
2.21k
}
431
432
Status MetaScanner::_build_partitions_metadata_request(const TMetaScanRange& meta_scan_range,
433
22
                                                       TFetchSchemaTableDataRequest* request) {
434
22
    VLOG_CRITICAL << "MetaScanner::_build_partitions_metadata_request";
435
22
    if (!meta_scan_range.__isset.partitions_params) {
436
0
        return Status::InternalError(
437
0
                "Can not find TPartitionsMetadataParams from meta_scan_range.");
438
0
    }
439
440
    // create request
441
22
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
442
443
    // create TMetadataTableRequestParams
444
22
    TMetadataTableRequestParams metadata_table_params;
445
22
    metadata_table_params.__set_metadata_type(TMetadataType::PARTITIONS);
446
22
    metadata_table_params.__set_partitions_metadata_params(meta_scan_range.partitions_params);
447
448
22
    request->__set_metada_table_params(metadata_table_params);
449
22
    return Status::OK();
450
22
}
451
452
Status MetaScanner::_build_jobs_metadata_request(const TMetaScanRange& meta_scan_range,
453
936
                                                 TFetchSchemaTableDataRequest* request) {
454
936
    VLOG_CRITICAL << "MetaScanner::_build_jobs_metadata_request";
455
936
    if (!meta_scan_range.__isset.jobs_params) {
456
0
        return Status::InternalError("Can not find TJobsMetadataParams from meta_scan_range.");
457
0
    }
458
459
    // create request
460
936
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
461
462
    // create TMetadataTableRequestParams
463
936
    TMetadataTableRequestParams metadata_table_params;
464
936
    metadata_table_params.__set_metadata_type(TMetadataType::JOBS);
465
936
    metadata_table_params.__set_jobs_metadata_params(meta_scan_range.jobs_params);
466
467
936
    request->__set_metada_table_params(metadata_table_params);
468
936
    return Status::OK();
469
936
}
470
471
Status MetaScanner::_build_tasks_metadata_request(const TMetaScanRange& meta_scan_range,
472
2.28k
                                                  TFetchSchemaTableDataRequest* request) {
473
2.28k
    VLOG_CRITICAL << "MetaScanner::_build_tasks_metadata_request";
474
2.28k
    if (!meta_scan_range.__isset.tasks_params) {
475
0
        return Status::InternalError("Can not find TTasksMetadataParams from meta_scan_range.");
476
0
    }
477
478
    // create request
479
2.28k
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
480
481
    // create TMetadataTableRequestParams
482
2.28k
    TMetadataTableRequestParams metadata_table_params;
483
2.28k
    metadata_table_params.__set_metadata_type(TMetadataType::TASKS);
484
2.28k
    metadata_table_params.__set_tasks_metadata_params(meta_scan_range.tasks_params);
485
486
2.28k
    request->__set_metada_table_params(metadata_table_params);
487
2.28k
    return Status::OK();
488
2.28k
}
489
490
Status MetaScanner::_build_partition_values_metadata_request(
491
20
        const TMetaScanRange& meta_scan_range, TFetchSchemaTableDataRequest* request) {
492
20
    VLOG_CRITICAL << "MetaScanner::_build_partition_values_metadata_request";
493
20
    if (!meta_scan_range.__isset.partition_values_params) {
494
0
        return Status::InternalError(
495
0
                "Can not find TPartitionValuesMetadataParams from meta_scan_range.");
496
0
    }
497
498
    // create request
499
20
    request->__set_schema_table_name(TSchemaTableName::METADATA_TABLE);
500
501
    // create TMetadataTableRequestParams
502
20
    TMetadataTableRequestParams metadata_table_params;
503
20
    metadata_table_params.__set_metadata_type(TMetadataType::PARTITION_VALUES);
504
20
    metadata_table_params.__set_partition_values_metadata_params(
505
20
            meta_scan_range.partition_values_params);
506
507
20
    request->__set_metada_table_params(metadata_table_params);
508
20
    return Status::OK();
509
20
}
510
511
5.59k
Status MetaScanner::close(RuntimeState* state) {
512
5.59k
    VLOG_CRITICAL << "MetaScanner::close";
513
5.59k
    if (!_try_close()) {
514
0
        return Status::OK();
515
0
    }
516
5.59k
    if (_reader) {
517
38
        RETURN_IF_ERROR(_reader->close());
518
38
    }
519
5.59k
    RETURN_IF_ERROR(Scanner::close(state));
520
5.59k
    return Status::OK();
521
5.59k
}
522
523
} // namespace doris