我有一个配置单元表列表,其中一些是分区的。给定一列,我需要检查特定表是否在该列上分区。
我搜索过并发现desc 格式的表名将产生表的所有详细信息。
由于我必须迭代所有表并获取列表,因此 desc 格式没有帮助。
有没有其他方法可以做到这一点。
您可以直接连接到元存储并查询它:
metastore=# select d."NAME" as DATABASE,
t."TBL_NAME" as TABLE,
p."PKEY_NAME" as PARTITION_KEY
from "PARTITION_KEYS" p
join "TBLS" t on p."TBL_ID"=t."TBL_ID"
join "DBS" d on t."DB_ID"=d."DB_ID";
database | table | partition_key
----------+-------------+---------------
default | src_union_1 | ds
default | cbo_t1 | dt
default | cbo_t2 | dt
查询元存储的确切语法取决于您对元存储的特定选择(在我的例子中是 PostgreSQL 元存储)。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)