PG创建or修改索引
admin
2023-03-12 11:02:10
0

pgsql中的索引不能重名,重名的创建失败。

 

创建二级索引的命令:create index CONCURRENTLY idx_abc on tb1(a,b);

 

注意:reindex 重建索引的过程是阻塞的,一般大表不建议使用这个命令,可以重建一个索引,然后删除老的索引。

 

下面看一个《PostgreSQL实战》书上page202的例子:

由于PGMVCC机制,当运行大量的更新操作后,会有索引膨胀的现象。这时候 可以通过 create index concurrently 不阻塞查询和更新的情况下,在线重新重建索引,创建好索引之后,再删除原先的索引,减少索引的尺寸,提高查询速度。对于主键也可以使用这种方式进行,例如:

db1=# \d testdata

                 Table "public.testdata"

  Column  |     Type     | Collation | Nullable | Default

----------+--------------+-----------+----------+---------

 id       | integer      |           | not null |

 course   | integer      |           |          |

 grade    | numeric(4,2) |           |          |

 testtime | date         |           |          |

Indexes:

    "testdata_pkey" PRIMARY KEY, btree (id)

 

db1=# create unique index concurrently on testdata using btree(id);

 

db1=# select

schemaname,

relname,

indexrelname,

pg_relation_size (indexrelid) as index_size,

idx_scan,

idx_tup_read,

idx_tup_fetch

from pg_stat_user_indexes where

indexrelname in (select indexname from pg_indexes where schemaname ='public' and tablename='testdata');

 schemaname | relname  |  indexrelname   | index_size | idx_scan | idx_tup_read | idx_tup_fetch

------------+----------+-----------------+------------+----------+--------------+---------------

 public     | testdata | testdata_pkey   |      16384 |        2 |      5999998 |       5999998

 public     | testdata | testdata_id_idx |      16384 |        0 |            0 |             0

(2 rows)

 

db1=# begin;

BEGIN

 

db1=# alter table testdata drop constraint testdata_pkey;

ALTER TABLE

 

db1=# alter table testdata add constraint testdata_id_idx primary key using index testdata_id_idx ;

ALTER TABLE

 

db1=# end;

COMMIT

 

db1=# \d testdata

                 Table "public.testdata"

  Column  |     Type     | Collation | Nullable | Default

----------+--------------+-----------+----------+---------

 id       | integer      |           | not null |

 course   | integer      |           |          |

 grade    | numeric(4,2) |           |          |

 testtime | date         |           |          |

Indexes:

    "testdata_id_idx" PRIMARY KEY, btree (id)

 

db1=# select

schemaname,

relname,

indexrelname,

pg_relation_size (indexrelid) as index_size,

idx_scan,

idx_tup_read,

idx_tup_fetch

from pg_stat_user_indexes where

indexrelname in (select indexname from pg_indexes where schemaname ='public' and tablename='testdata');

schemaname | relname  |  indexrelname   | index_size | idx_scan | idx_tup_read | idx_tup_fetch

------------+----------+-----------------+------------+----------+--------------+---------------

 public     | testdata | testdata_id_idx |      16384 |        0 |            0 |             0

(1 row)

 

 

这样就完成了主键索引的重建,对于大规模的数据库集群,可以通过 pg_repack 工具进行定时的索引重建。

 


相关内容

热门资讯

终于懂了“普通扑克三公保庄大有... 您好:普通扑克三公保庄大这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家...
【第一消息】“天天爱泰州麻将是... 您好:天天爱泰州麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这...
【今日要闻】“阿拉斗牌有挂吗?... 【今日要闻】“阿拉斗牌有挂吗?”(确实真的有挂)您好,阿拉斗牌这个游戏其实有挂的,确实是有挂的,需要...
终于懂了“AGPoker怎么装... 家人们!今天小编来为大家解答AGPoker透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪...
终于了解“葫芦娃犇犇是不是有挂... 家人们!今天小编来为大家解答葫芦娃犇犇透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买...
玩家攻略科普“新蓝鲸拼三张到底... 家人们!今天小编来为大家解答新蓝鲸拼三张透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
今日重大发现“hhpoker可... 家人们!今天小编来为大家解答hhpoker透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪...
今日重大通报“牵手跑胡子怎么装... 网上科普关于“牵手跑胡子有没有挂”话题很是火热,小编也是针对牵手跑胡子作*弊开挂的方法以及开挂对应的...
今日重磅消息“闲来贵州麻将开挂... 家人们!今天小编来为大家解答闲来贵州麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
今日重磅消息“新圣游牌九到底是... 有 亲,根据资深记者爆料新圣游牌九是可以开挂的,确实有挂(咨询软件无需打...