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

* картинки с технической информацией — зло! * у вас SELECT

FOR UPDATE для условия WHERE id IN ( $1, $2 ) — нет никакой гарантии, что записи будут блокироваться в последовательности аргументов в запросе. как база наткнётся, так и возьмёт лок. и просто наличие условия SELECT FOR UPDATE WHERE id IN ( $1, $2 ) — практически гарантия для дедлоков.

* зачем явные блокировки нужны? нельзя сделать просто UPDATE?

4 ответов

16 просмотров

1) а как лучше давать логи из консоли? 2) а можно как-то дополнительным / другим локом SELECT, чтобы он прошел по таблице и либо залочил одновременно два, либо повис в ожидании, пока другие не разлочат? кажется, также можно решить эту проблему активным ожиданием через суффикс NO WAIT и цикл, но не хочется активное ожидание в коде 3) просто UPDATE, кажется, не сработает же? когда транзакция делает UPDATE в двух аккаунтах, нужно, чтобы остальные, кто пытается работать с хотя бы одним из двух, повис как раз где-нибудь в SELECT FOR UPDATE и уже после получение доступа читал актуальные закомиченные данные P.S. если что, я только-только разбираюсь с транзакциями в sql по-хорошему, поэтому вот так P.P.S. документацию постгры, постгреспро, главу в книжке читал. не помогло до конца понять этот момент.

Виктор-Егоров Автор вопроса
Pavel Danilov
1) а как лучше давать логи из консоли? 2) а можно ...

1) копировать текстом, прикладывать текстом 2) UPADTE берёт такой же лок, что и SELECT FOR UPDATE. проблема не в локе, а в последовательности блокирования записей 3) сработает. но шанс получить дедлок сохраняется. 4) вы не ответили — вам точно надо блокировать сразу 2 id? можно же сделать транзакцию и в ней UPDATE меньшего из 2-х ID, затем большего из двух. 5) нет такой базы постгры, не коверкайте

Виктор Егоров
1) копировать текстом, прикладывать текстом 2) UPA...

кажется, вы правы, если задать порядок, сначала меньший id, потом больший, и провести так 2 update один за другим - этого достаточно.

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
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
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
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
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта