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

Добрый день, извиняюсь за глупый вопрос, можно ли через RULE

/ Trigger поменять местами значения при инсерте из разных колонок?
RULE приводит к бесконечной рекурсии, а через Trigger и INSTEAD OF + View как-то не получается

На примере вот этого правила:

CREATE OR REPLACE RULE relationship_status_ids_permute AS ON INSERT
TO relationship_status WHERE NEW.id_2 < NEW.id_1
DO INSTEAD INSERT INTO relationship_status
VALUES (NEW.id_2
NEW.id_1,
NEW.target_id,
NEW.created_at,
NEW.approved_at,
NEW.refused_at);


Заранее огромное спасибо за помощь

2 ответов

5 просмотров

Если можно вьюху, то можно так: CREATE TABLE relationship_status (id_1 int not null, id_2 int not null, target_id int, created_at timestamp, approved_at timestamp, refused_at timestamp); create view vw_relationship_status as (select * from relationship_status) CREATE OR REPLACE RULE relationship_status_ids_permute AS ON INSERT TO vw_relationship_status --WHERE NEW.id_2 < NEW.id_1 DO INSTEAD INSERT INTO relationship_status VALUES (LEAST(NEW.id_2,NEW.id_1), GREATEST(NEW.id_2,NEW.id_1), NEW.target_id, NEW.created_at, NEW.approved_at, NEW.refused_at);

1. Лучше никогда не используйте RULES, см. https://wiki.postgresql.org/wiki/Don%27t_Do_This#Don.27t_use_rules 2. А почему Вы говорите об INSTEAD OF? Куда у Вас идёт вставка, в таблицу (если да, то используйте BEFORE)?

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

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

Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
А чем вам питонисты не угодили?😂
.
79
Вот смотрите у меня есть два стрима сейчас fs, cs: TStream; fs := TFileStream.Create('filename'); cs := TCompressionStream.Create(compression_level, fs); Я хочу сделать так: ...
notme
5
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
83
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Hello. Could you please help me with finding all coordinates within a radius using a spatial index, given that I have a table with coordinates? SET @lng = 37.57925; SET @lat ...
Rinchin G
8
free(NULL) это UB?
#
8
Карта сайта