码迷,mamicode.com
首页 > 数据库 > 详细

GP数据库分布键查询

时间:2015-09-23 17:08:00      阅读:2428      评论:0      收藏:0      [点我收藏+]

标签:分布键

GP数据库中的表一般都会设置分布键,如果没有设置的话,它一般默认是第一个字段,所以一般会建议使用一个记录会分布均匀的字段作为分布键使用,使表中的记录均匀的分布到每一个segment中。

GP数据库分布键查询方法:

select c.schema_name,
       c.table_name,
       c.table_comment as "中文表明",
       c.column_name as "分布键",
  from ( select d.nspname as schema_name,
                c.relname as table_name,
                obj_description(c.oid) as table_comment,
                a.attname as column_name
           from pg_class c
           left join pg_attribute a
             on a.attrelid = c.oid
           join pg_namespace d
             on d.oid = c.relnamespace
           left join pg_inherits f
             on c.oid = f.inhrelid
          where a.attnum > 0
            and f.inhrelid is null)c
  join (select a.attrnums[i.i] as a.attrnums,
               b.attname,
               a.localoid::regclass as localoid
          from gp_distribution_policy a,
               (select generate_series(1,10) as generate_series) i(i),
               pg_attribute b
        where a.attrnums[i.i] is not null
          and a.localoid = b.attrelid
          and a.attrnums[i.i] = b.attnum) t
    on c.column_name = t.attname
   and ((c.schema_name::text || ‘.‘::text) || a.table_name::text)::regclass::oid = t.localoid::oid
 order by c.schema_name,
          c.table_name,
          c.column_name
;

GP数据库分布键查询

标签:分布键

原文地址:http://6666613.blog.51cto.com/6656613/1697524

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!