溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PostgreSQL12的新特性REINDEX有什么作用

發(fā)布時(shí)間:2021-11-09 11:20:21 來源:億速云 閱讀:703 作者:iii 欄目:關(guān)系型數(shù)據(jù)庫

這篇文章主要介紹“PostgreSQL12的新特性REINDEX有什么作用”,在日常操作中,相信很多人在PostgreSQL12的新特性REINDEX有什么作用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PostgreSQL12的新特性REINDEX有什么作用”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

PG 12引入REINDEX
CONCURRENTLY,為了解決在REINDEX期間不能執(zhí)行查詢操作的問題,REINDEX CONCURRENTLY使用了相對于pg_repack(前身是pg_reorg)成本更低的方法來實(shí)現(xiàn)在索引rebuild期間數(shù)據(jù)表的可讀寫查詢,但rebuild的時(shí)間越長,需要的資源越多,其實(shí)現(xiàn)思路如下:
1.創(chuàng)建新的索引(在與原index一樣的catalog中),以_ccnew結(jié)尾
2.構(gòu)建新索引,這一步會并行去做
3.使新索引與在構(gòu)建期間出現(xiàn)的變化同步(catch up)
4.重命名新索引為舊索引的名稱并切換所有依賴舊索引的地方到新索引.舊索引設(shè)置為invalid(這一步成為交換)
5.標(biāo)記舊索引為dead狀態(tài)(vacuum進(jìn)程可回收)
6.刪除索引
上面每一步都需要事務(wù).在reindexing table時(shí),該表的所有索引會一次過進(jìn)行收集每一步都會處理所有的索引.可以把這個(gè)過程視為在一個(gè)單獨(dú)的事務(wù)中CREATE INDEX CONCURRENTLY后跟DROP INDEX的組合,中間有一步是完全透明的新舊索引切換.
如果在REINDEX期間出現(xiàn)異常,那么所有需要rebuild的索引的狀態(tài)都是invalid,意味著這些索引仍然占用空間,定義仍在但不能使用.

下面是測試腳本,PG 11 vs PG 12的一些區(qū)別
PG 11

testdb=# CREATE TABLE tab (a int);
CREATE TABLE
testdb=# INSERT INTO tab VALUES (1),(1),(2);
INSERT 0 3
testdb=# CREATE UNIQUE INDEX CONCURRENTLY tab_index on tab (a);
ERROR:  could not create unique index "tab_index"
DETAIL:  Key (a)=(1) is duplicated.
testdb=# \d tab
                Table "public.tab"
 Column |  Type   | Collation | Nullable | Default 
--------+---------+-----------+----------+---------
 a      | integer |           |          | 
Indexes:
    "tab_index" UNIQUE, btree (a) INVALID
testdb=# REINDEX TABLE tab;
ERROR:  could not create unique index "tab_index"
DETAIL:  Key (a)=(1) is duplicated.
testdb=#  DELETE FROM tab WHERE a = 1; 
DELETE 2
testdb=# REINDEX TABLE tab;
REINDEX

PG 12

testdb=#  CREATE TABLE tab (a int);
CREATE TABLE
testdb=# INSERT INTO tab VALUES (1),(1),(2);
INSERT 0 3
testdb=#  CREATE UNIQUE INDEX CONCURRENTLY tab_index on tab (a);
psql: ERROR:  could not create unique index "tab_index"
DETAIL:  Key (a)=(1) is duplicated.
testdb=#  REINDEX TABLE CONCURRENTLY tab;
psql: WARNING:  cannot reindex invalid index "public.tab_index" concurrently, skipping
psql: NOTICE:  table "tab" has no indexes
REINDEX
testdb=#  DELETE FROM tab WHERE a = 1; 
DELETE 2
testdb=#  REINDEX TABLE CONCURRENTLY tab;
psql: WARNING:  cannot reindex invalid index "public.tab_index" concurrently, skipping
psql: NOTICE:  table "tab" has no indexes
REINDEX
testdb=#  REINDEX INDEX CONCURRENTLY tab_index;
REINDEX
testdb=#

PG 12自動跳過了invalid index.

到此,關(guān)于“PostgreSQL12的新特性REINDEX有什么作用”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI