Greenplum

  1. 查询哪个表的分布键 ( Greenplum )

    SELECT
    att.nspname AS 模式名
    , att.relname AS 表名
    , table_comment AS 表注释
    , string_agg (a.attname, '、') AS 分布键
    FROM
    (
    SELECT c.oid
    , obj_description(c.oid) AS table_comment
    , n.nspname,c.relname,regexp_split_to_table (array_to_string (d.distkey, ' '),' ')::int as attnu
    FROM gp_distribution_policy d
    LEFT JOIN pg_class c ON c.oid = d.localoid
    LEFT JOIN pg_namespace n ON n.oid = c.relnamespace
    WHERE c.oid = 'u_dws.opn_label_factory_user_group'::regclass -- '模式名.表名'::regclass
    ) att
    LEFT JOIN pg_attribute a ON a.attrelid = att.oid
    WHERE att.attnu = a.attnum
    GROUP BY 1,2,3
    ;

    或者是:

    SELECT
    aaa.oid,
    aaa.nspname AS "模式名",
    aaa.relname AS "表名",
    aaa.table_comment AS "中文表名",
    ccc.attname AS "分布键"
    FROM
    (
    SELECT
    aa.oid,
    aa.relname,
    obj_description ( aa.oid ) AS table_comment,
    bb.localoid,
    bb.distkey,
    regexp_split_to_table( array_to_string( bb.distkey, ' ' ), ' ' ) att,
    dd.nspname
    FROM
    pg_class aa
    LEFT JOIN pg_catalog.gp_distribution_policy bb ON bb.localoid = aa.oid
    LEFT JOIN pg_namespace dd ON dd.oid = aa.relnamespace --模式
    LEFT JOIN pg_inherits hh ON aa.oid = hh.inhrelid --继承表
    WHERE
    dd.nspname = 'u_dws_dev' -- 替换成需要的模式schema
    AND hh.inhrelid IS NULL
    ) aaa
    LEFT JOIN pg_attribute ccc ON ccc.attrelid = aaa.oid
    AND CAST ( ccc.attnum AS TEXT ) = aaa.att
    WHERE
    ccc.attnum > 0
    AND aaa.relname = 'opn_label_factory_user_group' --需要查询的表名
    ;
  2. 查看每个表的表注释 ( Greenplum )

      -- 直接执行就可以
    with tmp_tab as (
    select pc.oid as ooid,pn.nspname,pc.*
    from pg_class pc
    left outer join pg_namespace pn
    on pc.relnamespace = pn.oid
    where 1=1
    and pc.relkind in ('r')
    and pn.nspname not in ('pg_catalog','information_schema') -- select pn.oid, pn.* from pg_namespace pn where 1=1
    and pn.nspname not like 'pg_toast%'
    and pc.oid not in (
    select inhrelid
    from pg_inherits
    )
    and pc.relname not like '%peiyb%'
    order by pc.relname
    ),tmp_desc as (
    select pd.*
    from pg_description pd
    where 1=1
    and pd.objsubid = 0 --objsubid 对于一个表列上的一个注释,这里是列号(objoid和classoid指表本身)。对所有其他对象类型,此列为0。
    --and pd.objoid=168605
    )
    select t0.*
    from (
    select tab.relname as table_name, -- tab.relname:表名
    de.description -- de.description:表注释
    from tmp_tab tab
    left outer join tmp_desc de
    on tab.ooid = de.objoid
    where 1=1 and tab.nspname = 'ods_rk' -- and tab.relname='your_table_name' -- tab.nspname:模式名
    ) t0
    where 1=1;
  3. 通过MYSQLGreenplum加注释

  • 加表注释

     select
    CONCAT('COMMENT ON TABLE "edc_rk"."', a.TABLE_NAME, '" IS ''', a.TABLE_COMMENT, ''';') AS `SQL`
    from information_schema.TABLES a
    where a.TABLE_SCHEMA = 'edc_rk' and a.TABLE_NAME not like '%copy%'
    ORDER BY a.TABLE_NAME
    ;
  • 加列注释

    select
    b.ORDINAL_POSITION AS 列序号
    , CONCAT('COMMENT ON COLUMN "edc_rk"."', a.TABLE_NAME, '"."', b.COLUMN_NAME, '" IS ''', b.COLUMN_COMMENT, ''';') AS `SQL`
    from information_schema.TABLES a left join information_schema.COLUMNS b
    on a.TABLE_SCHEMA = 'edc_rk'-- and SUBSTR(a.TABLE_COMMENT, 1, 1) = '|'
    and a.TABLE_SCHEMA = b.TABLE_SCHEMA and a.TABLE_NAME = b.TABLE_NAME
    where a.TABLE_SCHEMA = 'edc_rk' and a.TABLE_NAME not like '%copy%' and a.TABLE_NAME <> 'sheet1'
    ORDER BY a.TABLE_NAME, b.ORDINAL_POSITION
    ;
  1. 查询字段的注释等相关信息

    SELECT UPPER(A.SCHEMANAME) AS SCHEMANAME,
    UPPER(A.TABLENAME) AS TABLENAME,
    --D.ATTRELID ,
    --D.ATTRELID::regclass,
    UPPER(D.ATTNAME) AS ATTNAME,
    REPLACE(REPLACE(REPLACE(FORMAT_TYPE(D.ATTTYPID, D.ATTTYPMOD),
    'numeric',
    'NUMBER'),
    'character varying',
    'VARCHAR2'),
    'date',
    'DATE') AS DATA_TYPE,
    E.DESCRIPTION
    FROM PG_TABLES A
    INNER JOIN PG_CLASS B
    ON A.TABLENAME = B.RELNAME
    LEFT JOIN PG_CATALOG.PG_DESCRIPTION E
    ON B.OID = E.OBJOID
    LEFT JOIN PG_CATALOG.PG_ATTRIBUTE D
    ON D.ATTRELID = E.OBJOID
    AND D.ATTNUM = E.OBJSUBID
    WHERE SCHEMANAME = 'pmart_risk'
    AND A.TABLENAME LIKE '%表名称%'
    AND D.ATTNUM > 0
    ORDER BY A.TABLENAME ,D.ATTNUM
    ;

【有用的SQL】查Greenplum的数据字典的更多相关文章

  1. 三个有用的SQL辅助工具

    三个有用的SQL辅助工具 编写人:CC阿爸 2015-1-23 工欲善其事必先利其器,今天在这里,我想与大家一起分享三个有用的SQL辅助工具.有兴趣的同学,可以一同探讨与学习一下,否则就略过吧. 相信 ...

  2. sql查重去除id最小值

    select order_id FROM yzj_store_order t WHERE (t.user_id,t.order_status) IN ( SELECT user_id,order_st ...

  3. greenplum(postgresql) 数据字典

    greenplum是基于postgresql开发的分布式数据库,里面大部分的数据字典是一样的.我们在维护gp的时候对gp的数据字典比较熟悉,特此分享给大家.在这里不会详细介绍每个字典的内容,只会介绍常 ...

  4. 比较有用的sql语句

    一.基础 .说明:创建数据库 CREATE DATABASE database-name .说明:删除数据库 drop database dbname .说明:备份sql server --- 创建 ...

  5. SQL查临时表没有返回数据集

    问题描述:在SQL中可以查询到数据,返回不到页面上. 解决办法: set nocount on create table #list [转] 每次我们在使用查询分析器调试SQL语句的时候,通常会看到一 ...

  6. PowerDesigner根据SQL文件生成PDM数据字典

    当PowerDesigner不能直接连接到数据库的时候,可以用到下面这个方法生成数据字典(直接连接数据库生成数据字典在上次随笔中有介绍). 具体操作步骤截图: ↓↓↓这里选择的sql文件是从数据库导出 ...

  7. 我试了试用 SQL查 Linux日志,好用到飞起

    大家好,我是小富~ 最近发现点好玩的工具,迫不及待的想跟大家分享一下. 大家平时都怎么查Linux日志呢? 像我平时会用tail.head.cat.sed.more.less这些经典系统命令,或者aw ...

  8. 有用的sql语句积累

    ⑴.  sql查询未被外键关联的数据 select * from bb b where not exists (select 1 from aa a where a.bid=b.bid)

  9. 利用hive源码解析sql查了哪些表哪些字段

    在hiveserver2中使用了org.apache.hadoop.hive.ql.parse.BaseSemanticAnalyzer对抽象语法树(AST)进行语义分析,分析的过程可以得出hive查 ...

随机推荐

  1. 五四青年节,今天要学习。汇总5道难度不高但可能遇到的JS手写编程题

    壹 ❀ 引 时间一晃,今天已是五一假期最后一天了,没有出门,没有太多惊喜与意外.今天五四青年节,脑子里突然想起鲁迅先生以及悲欢并不相通的话,我的五一经历了什么呢,忍不住想说那大概是,父母教育孩子大声嚷 ...

  2. Linux操作系统,为什么需要内核空间和用户空间?

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 本文以 32 位系统为例介绍内核空间(kernel sp ...

  3. Vue.js 3.x 双向绑定原理

    什么是双向绑定? 废话不多说,我们先来看一个 v-model 基本的示例: <input type="text" v-model="search"> ...

  4. C#开发PACS医学影像三维重建(十三):基于人体CT值从皮肤渐变到骨骼的梯度透明思路

    当我们将CT切片重建为三维体之后,通常会消除一些不必要的外部组织来观察内部病灶, 一般思路是根据人体常见CT值范围来使得部分组织透明来达到效果, 但这是非黑即白的,即,要么显示皮肤,要么显示神经,要么 ...

  5. 老生常谈系列之Aop--前言

    老生常谈系列之Aop--前言 前言 既然是前言,那么这一篇就不会写具体的技术问题.这篇文章主要记录我一些个人的思考以及为什么要写文章的缘由.前不久在跟朋友的交流中偶然聊到了Aop,Aop全称为 Asp ...

  6. Spring 源码(11)Spring Bean 的创建过程(2)

    Spring Bean 的创建过程介绍了FactoryBean 的创建方式,那么接下来介绍不是FactoryBean的创建方式,在创建过程中,又会分为单例的Bean的创建,原型类型的Bean的创建等. ...

  7. 斯坦福NLP课程 | 第11讲 - NLP中的卷积神经网络

    作者:韩信子@ShowMeAI,路遥@ShowMeAI,奇异果@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/36 本文地址:http://www. ...

  8. 709. To Lower Case - LeetCode

    Question 709. To Lower Case Sollution 题目大意:字符串大写转小写 思路: 直接调用Java API函数 字符串转char数组,遍历数组,判断如果大写就转小写 Ja ...

  9. 做一个能对标阿里云的前端APM工具(下)

    上篇请访问这里做一个能对标阿里云的前端APM工具(上) 样本多样性问题 上一小节中的实施方案是微观的,即单次性的.具体的.但是从宏观上看,我需要保证性能测试是公允的,符合大众预期的.为了达到这种效果, ...

  10. Tmux终端复用神器使用心得

    tmux在连接远程服务器做实验时很有帮助,可以为每一个项目设置一个Session,在Session中设置不同的Window同时跑多个实验,Window本身还可以分割为多个Pane,在一个视野内利用多个 ...