KingbaseES(1) : 查询当前数据库所有表和描述

SELECT 
    pgc.relname AS table_name,
    pgd.description AS table_description
FROM 
    pg_class pgc
LEFT JOIN 
    pg_description pgd ON (pgc.oid = pgd.objoid AND pgd.objsubid = 0)
JOIN 
    pg_namespace pgn ON pgn.oid = pgc.relnamespace
WHERE 
    pgc.relkind = 'r' -- 'r'代表普通表
AND 
    pgn.nspname = 'public';

在这个查询中:

  • sys_class 是包含数据库对象信息的系统表。
  • relname 是表的名称。
  • sys_description 包含对象的描述信息(注释),其中objoid指向对象的OID,objsubid为0表示这是一个对象级别的注释(而非列级别)。
  • relkind = 'r' 确保只选择普通表。
  • relnamespace 来过滤特定模式下的表,在这个例子中为public模式。如果你想要查看其他模式下的表,你需要将nspname替换为目标模式的名称。

请注意,具体的系统表名、字段名等可能会因版本不同而有所差异。建议参考您所使用的KingbaseES版本的官方文档以获得最准确的信息。

此外,如果您发现上述查询未能如预期工作,请确保您有足够的权限访问系统表,并且您的数据库确实使用注释来存储表的描述信息。如果没有找到相应的描述,可能是因为没有为表设置描述信息。在这种情况下,您可以使用COMMENT ON TABLE语句为表添加描述。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值