common_meta/ddl/utils/
table_id.rs1use snafu::OptionExt;
16use store_api::storage::TableId;
17use table::table_reference::TableReference;
18
19use crate::error::{Result, TableNotFoundSnafu};
20use crate::key::table_name::{TableNameKey, TableNameManager};
21
22pub(crate) async fn get_all_table_ids_by_names<'a>(
26    table_name_manager: &TableNameManager,
27    table_names: &[TableReference<'a>],
28) -> Result<Vec<TableId>> {
29    let table_name_keys = table_names
30        .iter()
31        .map(TableNameKey::from)
32        .collect::<Vec<_>>();
33    let table_name_values = table_name_manager.batch_get(table_name_keys).await?;
34    let mut table_ids = Vec::with_capacity(table_name_values.len());
35    for (value, table_name) in table_name_values.into_iter().zip(table_names) {
36        let value = value
37            .with_context(|| TableNotFoundSnafu {
38                table_name: table_name.to_string(),
39            })?
40            .table_id();
41
42        table_ids.push(value);
43    }
44
45    Ok(table_ids)
46}