Postgresql如何获取表结构

SELECT
    COALESCE(SPLIT_PART(t.COMMENT, ':', 1), c.column_name) AS "コメント名"
    , c.column_name AS "列の名前"
    , (

        CASE c.udt_name
            WHEN 'date' THEN 'DateTime'
            WHEN 'varchar' THEN 'string'
            WHEN 'text' THEN 'string'
            WHEN 'timestamp' THEN 'DateTime'
            WHEN 'numeric' THEN 'decimal'
            ELSE (

                CASE
                    WHEN strpos(c.udt_name, 'int') > 0
                        THEN 'decimal'
                    ELSE c.udt_name
                    END

            )
            END

    ) AS "を選択してオプションを設定します。"
    , ordinal_position AS "行の順序"
    , DENSE_RANK() OVER (ORDER BY c.table_name) AS "表の順序"
    , c.table_name AS "テーブル名"
FROM
    information_schema.columns c
    LEFT JOIN (
        SELECT
            a.table_name AS table_name
            , a.column_name AS column_name
            , a.data_type AS data_type
            , a.COMMENT AS COMMENT
        FROM
            (
                SELECT
                    pg_stat_user_tables.relname AS table_name
                    , information_schema.columns.column_name AS column_name
                    , information_schema.columns.data_type AS data_type
                    , (
                        SELECT
                            description
                        FROM
                            pg_description
                        WHERE
                            pg_description.objoid = pg_stat_user_tables.relid
                            AND pg_description.objsubid = information_schema.columns.ordinal_position
                    ) AS COMMENT
                FROM
                    pg_stat_user_tables
                    , information_schema.columns
                WHERE
                    pg_stat_user_tables.relname = information_schema.columns.table_name
                    AND pg_stat_user_tables.schemaname = current_schema()
            ) AS a
        WHERE
            a.COMMENT IS NOT NULL
    ) t
        ON c.table_name = t.table_name
        AND c.column_name = t.column_name
WHERE
    table_schema = 'public' -- schemaname
ORDER BY
    c.table_name
    , ordinal_position;

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值