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

Доброго времени суток, дайте ссылку на материал об уровнях изоляции

транзакций в пг и как они коррелируют с поддержкой целостности/уникальности индексов.
Кейс такой: есть таблица lock со столбцами resource и acquired. По resource построен уникальный индекс. Запрос на вставку выглядит так:
INSERT INTO lock(resource, acquired)
VALUES (@resource, current_timestamp at time zone 'UTC')
ON CONFLICT (resource) DO NOTHING
Нужно ли мне здесь что-то под транзакцией делать?

1 ответов

18 просмотров

Целостность, обеспечиваемая самим PostgreSQL (unique/foreign key/check), поддерживается в любом случае. INSERT ... ON CONFICT гарантирует вам, что если транзакция выполнится, то, незавимо от наличия параллельных транзакций, вставка произойдёт (или будет игнорирована) так, как должно было быть, если бы их не было.

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта