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 ответов

7 просмотров

Добрый день! Нет, не говорил. Я же Вам писал, кажется — Ваш прошлый пример был просто слишком большим (и, видно, кончилось 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. Т.е. максимум, чего тут можно добиться, как мне кажется — изменения документации, чтобы было понятнее написано.

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
@y0zhig @shizzard А можно я опишу цель и может вообще ерланг мне не подходит. На текущий момент как я понимаю у ерланга есть легковесные потоки и задача выполняется в каком т...
Дмитрий Спиридонов
5
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Карта сайта