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

Народ, подскажите, где описывается, что нельзя использовать for update с

join-ами или почему получаю такую ошибку?

ERROR: FOR UPDATE cannot be applied to the nullable side of an outer join

7 ответов

36 просмотров

Очевидно же - если в приджойненной таблице по условию джойна ничего не нашлось, то и лочить нечего.

Guzya- Автор вопроса
Anatoly Shuravin
Очевидно же - если в приджойненной таблице по усло...

Так я лочу не приджойненую таблицу, а записи, которые подбираются в итоге: with batch(id) as ( SELECT vsct.id FROM vsct left join table_2 r on r.id=vsct.release_id where r.id is null order by id for update skip locked ), del as ( delete from vsct where id in (select id from batch) returning * )

Guzya
Так я лочу не приджойненую таблицу, а записи, кото...

А "записи, которые подбираются в итоге" — это записи отношения, которое является внешним соединением отношений vsct и table_2, нет (т.е. lock должен накладываться на обе таблицы)? (Ехидно) Вот до чего доводит использование аляповатых конструкций вместо NOT EXISTS. Но можете просто указать FOR UPDATE OF vsct SKIP LOCKED, если переписывать не хочется.

Guzya- Автор вопроса
Yaroslav Schekin
А "записи, которые подбираются в итоге" — это запи...

работа уже выполнена, просто хотел разобраться. Я так понял итог такой, если в "области" select могут быть указаны колонки из других таблиц, то эти таблицы так же лочятся.

Guzya
работа уже выполнена, просто хотел разобраться. Я ...

Не имеет значения, что там указано в SELECT list (хоть SELECT 1 напишите). Важно, откуда выбираются записи в отношение-результат.

Guzya- Автор вопроса
Anatoly Shuravin
Очевидно же - если в приджойненной таблице по усло...

Мне неочнвидно. То есть нечего лочить — ну, не лочь, делов-то.

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

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

а через 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
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
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта