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

День добрый, Yaroslav я тут всё со своей битемпоральностью, пардон.



Хотел спросить, говорили ли вы с коллегами по поводу INSTEAD OF DELETE триггера. Что когда в нём изменяем OLD, то изменйнные данные не становятся входом для следующего триггера. Несмотря на то, что в доке сказано:

In the case of BEFORE and INSTEAD OF triggers, the possibly-modified row returned by each trigger becomes the input to the next trigger
https://www.postgresql.org/docs/current/trigger-definition.html

Пример: https://dbfiddle.uk/?rdbms=postgres_12&fiddle=e875ac4e510681d9fc08fddf4f1374d1

1 ответов

18 просмотров

Добрый день! Нет, не говорил. Я же Вам писал, кажется — Ваш прошлый пример был просто слишком большим (и, видно, кончилось tl;dr). :( Да и вообще, лично мне поход стандарта к (bi)temporal не нравится, поэтому помогать внедрять его в PostgreSQL совершенно не хочется. А по поводу примера — в доке также сказано: A row-level INSTEAD OF trigger should either return NULL to indicate that it did not modify any data from the view's underlying base tables, or it should return the view row that was passed in (the NEW row for INSERT and UPDATE operations, or the OLD row for DELETE operations). For INSERT and UPDATE operations, the trigger may modify the NEW row before returning it. This will change the data returned by INSERT RETURNING or UPDATE RETURNING, and is useful when the view will not show exactly the same data that was provided. Т.е. максимум, чего тут можно добиться, как мне кажется — изменения документации, чтобы было понятнее написано.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта