Postgres UPSERT с ОГРАНИЧЕНИЕМ ИСКЛЮЧЕНИЯ - PullRequest
3 голосов
/ 13 июля 2020

Учитывая следующую таблицу:

create table some_table
(
    id                 uuid      default uuid_generate_v4() not null,
    last_modified_date timestamp default now()              not null,
    foreign_key        text,
    start              integer,
    end                integer,
    constraint some_table_pkey
        primary key (id),
    constraint some_table_foreign_key_fkey
        foreign key (foreign_key) references foreign_table
);

Затем я добавил следующие ограничения:

CREATE INDEX some_table_foreign_key_idx
    ON some_table (foreign_key);

ALTER table some_table
    ADD CONSTRAINT some_table_start_check
        check (start > 0);

ALTER TABLE some_table
    add CONSTRAINT some_table_check
        check (end >= start);

ALTER TABLE some_table
    ADD CONSTRAINT unique_interval_to_foreign_key_constraint
        EXCLUDE USING gist
        (foreign_key WITH =,
         int4range(start, end, '[]') WITH &&
        );

Создание такой таблицы:

+--------------------------------------+-------+-----+--------------------+--------------------------------------+
| id                                   | start | end | last_modified_date | foreign_key                          |
+--------------------------------------+-------+-----+--------------------+--------------------------------------+
| 04ef8258-917c-46d6-8db4-9c704d3f4fbd | 10    | 20  | timestampA         | 04ef8258-917c-46d6-8db3-9c704d3f4fbd |
+--------------------------------------+-------+-----+--------------------+--------------------------------------+
| 04ef8258-917c-46d6-8db5-9c704d3f4fbd | 40    | 60  | timestampB         | 04ef8258-917c-46d6-8db3-9c704d3f4fbd |
+--------------------------------------+-------+-----+--------------------+--------------------------------------+

Как сделать I INSERT запись в эту таблицу?

Что я пробовал?

INSERT INTO some_table (foreign_key, start, end) 
VALUES (`04ef8258-917c-46d6-8db3-9c704d3f4fbd`,  70, 80) 
ON CONFLICT (foreign_key, start, end) 
   DO UPDATE SET last_modified_date=NOW() RETURNING id;

Я получаю следующую ошибку:

UnableToExecuteStatementException: org. postgresql .util.PSQLException: ERROR: ON CONFLICT DO UPDATE требует спецификации вывода или имени ограничения

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...