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

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

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

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

7 ответов

41 просмотр

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

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
Очевидно же - если в приджойненной таблице по усло...

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
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...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно 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
Карта сайта