开发者社区 > PolarDB开源 > PolarDB 分布式版 > 正文

polardb中如何查询表和sequence的关联啊?

"polardb中如何查询表和sequence的关联啊?
\d \d+ 都没有显示sequence。我看网上的图, \d 会有 modifiers这一列,我的表也配置了sequence 为啥 我\d 没有这个modifiers。
6513df5c464edee98cd44a7e7d6c7953.png"

展开
收起
十一0204 2023-12-12 23:29:06 123 0
2 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    在PolarDB中,可以通过查询pg_classpg_namespacepg_attribute等系统表来获取表和sequence的关联信息。以下是一个查询示例:

    SELECT n.nspname AS schema_name, c.relname AS table_name, a.attname AS column_name, s.relname AS sequence_name
    FROM pg_class c
    JOIN pg_namespace n ON c.relnamespace = n.oid
    JOIN pg_attribute a ON a.attrelid = c.oid
    LEFT JOIN pg_class s ON s.relkind = 'S' AND a.attnum = ANY(s.relfrozenxid)
    WHERE c.relkind = 'r';
    

    这个查询将返回表名(table_name)、列名(column_name)以及与之关联的序列名(sequence_name)。请注意,这个查询可能需要根据您的实际数据库环境进行调整。

    2023-12-13 14:38:47
    赞同 1 展开评论 打赏
  • 在 PostgreSQL 中,\d 命令用于显示表的详细信息,包括列、约束、继承关系等。然而,\d 命令并不直接显示表和序列(sequence)的关联。

    如果你想查看表和序列的关联,你可以使用以下查询:

    SELECT  
        c.oid,  
        c.relname AS table_name,  
        pg_get_userbyid(relowner) AS table_owner,  
        s.relname AS sequence_name,  
        pg_get_userbyid(s.relowner) AS sequence_owner  
    FROM  
        pg_class c  
    JOIN  
        pg_namespace ns ON c.relnamespace = ns.oid  
    JOIN  
        pg_class s ON c.reltoastrelid = s.oid  
    WHERE  
        ns.nspname = 'your_schema_name' -- 替换为你的 schema 名称  
        AND c.relname = 'your_table_name' -- 替换为你的表名称
    

    这个查询将返回与指定表关联的序列的信息,包括序列的名称、所有者等。

    至于你提到的 \d 命令没有显示 "modifiers" 的问题,这可能是因为你的 PostgreSQL 版本或配置与网上示例有所不同。在某些版本或配置中,\d 命令可能不会显示 "modifiers" 列。

    2023-12-13 10:43:51
    赞同 展开评论 打赏

PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 是阿里云自主设计研发的高性能云原生分布式数据库产品,为用户提供高吞吐、大存储、低延时、易扩展和超高可用的云时代数据库服务。

相关电子书

更多
云栖大会:开源 PolarDB 架构演进、关键技术与社区建设 立即下载
2023云栖大会:和客户一起玩转PolarDB新特性 立即下载
2023云栖大会:PolarDB for AI 立即下载