При удалении тоже, но сама процедура проще. Так как записи в индексе только помечаются удаленными... Фактически апдейт...
при DELETE индекс не изменяется иначе сломался бы индексный поиск в соседних транзакциях так как в индексе нет атрибутов для определения видимости записи, они только в куче
почитайте https://www.postgresql.org/docs/current/btree-implementation.html#BTREE-DELETION
test=# \d ttt Table "public.ttt" Column | Type | Collation | Nullable | Default --------+---------+-----------+----------+--------- id | integer | | not null | v | text | | | Indexes: "ttt_pkey" PRIMARY KEY, btree (id) CLUSTER test=# select pg_current_wal_insert_lsn(); pg_current_wal_insert_lsn --------------------------- 0/1D2A6448 test=# insert into ttt values (2, 'line number 2'); INSERT 0 1 test=# select pg_current_wal_insert_lsn(); pg_current_wal_insert_lsn --------------------------- 0/1D2A65D0 test=# delete from ttt where id = 2; DELETE 1 test=# select pg_current_wal_insert_lsn(); pg_current_wal_insert_lsn --------------------------- 0/1D2A6678 postgres@9d2bbfdc46b8:~$ /usr/lib/postgresql/15/bin/pg_waldump -p data/pg_wal -s 0/1D2A6448 lsn: 0/1D2A6448, prev 0/1D2A6410, desc: INSERT off 2 flags 0x08, blkref #0: rel 1663/16388/39403 blk 0 FPW lsn: 0/1D2A6518, prev 0/1D2A6448, desc: INSERT_LEAF off 2, blkref #0: rel 1663/16388/39405 blk 1 FPW lsn: 0/1D2A65A0, prev 0/1D2A6518, desc: COMMIT 2023-09-24 14:11:17.435481 UTC lsn: 0/1D2A65D0, prev 0/1D2A65A0, desc: RUNNING_XACTS nextXid 14420 latestCompletedXid 14419 oldestRunningXid 14420 lsn: 0/1D2A6608, prev 0/1D2A65D0, desc: DELETE off 2 flags 0x04 KEYS_UPDATED , blkref #0: rel 1663/16388/39403 blk 0 lsn: 0/1D2A6648, prev 0/1D2A6608, desc: COMMIT 2023-09-24 14:11:36.051105 UTC lsn: 0/1D2A6678, prev 0/1D2A6648, desc: RUNNING_XACTS nextXid 14421 latestCompletedXid 14420 oldestRunningXid 14421
тут нет изменения файла индекса, я проверил прежде чем написать :-)
уточните, где “тут”? в примере вашем?
Обсуждают сегодня