172 похожих чатов

7 ответов

18 просмотров

При удалении тоже, но сама процедура проще. Так как записи в индексе только помечаются удаленными... Фактически апдейт...

Liman -
При удалении тоже, но сама процедура проще. Так ка...

при DELETE индекс не изменяется иначе сломался бы индексный поиск в соседних транзакциях так как в индексе нет атрибутов для определения видимости записи, они только в куче

S B
при DELETE индекс не изменяется иначе сломался бы ...

почитайте https://www.postgresql.org/docs/current/btree-implementation.html#BTREE-DELETION

Виктор Егоров
почитайте https://www.postgresql.org/docs/current...

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

Виктор Егоров
почитайте https://www.postgresql.org/docs/current...

тут нет изменения файла индекса, я проверил прежде чем написать :-)

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта