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}