检查表和索引的填充因子设置

10
也许有一些函数可以检查索引和表的填充因子?我已经尝试了\d+,但只有基本定义,没有填充因子的值:
        Index "public.tab1_pkey"
 Column |  Type  | Definition | Storage 
--------+--------+------------+---------
 id     | bigint | id         | plain
primary key, btree, for table "public.tab1"

关于表格,我没有找到任何信息。如果该表格是使用除默认值以外的fillfactor创建的:

CREATE TABLE distributors (
    did     integer,
    name    varchar(40),
    UNIQUE(name) WITH (fillfactor=70)
)
WITH (fillfactor=70);

然后\d+个分销商显示了非标准的填充因子。

                            Table "public.distributors"                                                                                                                                        
 Column |         Type          | Modifiers | Storage  | Stats target | Description                                                                                                            
--------+-----------------------+-----------+----------+--------------+-------------                                                                                                           
 did    | integer               |           | plain    |              |                                                                                                                        
 name   | character varying(40) |           | extended |              |                                                                                                                        
Indexes:                                                                                                                                                                                       
    "distributors_name_key" UNIQUE CONSTRAINT, btree (name) WITH (fillfactor=70)                                                                                                               
Has OIDs: no
Options: fillfactor=70

也许有一种方法可以在不解析输出的情况下获得这个值?
1个回答

22
您需要查询pg_class系统表:
select t.relname as table_name, 
       t.reloptions
from pg_class t
  join pg_namespace n on n.oid = t.relnamespace
where t.relname in ('tab11_pkey', 'tab1')
  and n.nspname = 'public'

reloptions是一个数组,每个元素包含一个option=value的定义。但对于具有默认选项的关系,它将为null。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接