Coverage Report

Created: 2026-05-18 16:07

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