Какие реализации upsert для Postgresql 9.3 вы рекомендуете использовать?

Задача:
повторить mysql-поведение "ON DUPLICATE KEY UPDATE" для postgresql 9.3 наименее извращенным способом
  • Вопрос задан
  • 1559 просмотров
Решения вопроса 1
@vovik0134
До версии 9.5 можно использовать следующее решение:
WITH upsert AS ( 
UPDATE tbl SET foo = 42 RETURNING * 
) 
INSERT INTO tbl(foo) VALUES(42) WHERE tbl.id NOT IN (SELECT id FROM upsert);


В 9.5 будет INSERT INTO ... ON CONFLICT
Ответ написан
Пригласить эксперта
Ответы на вопрос 2
@RekGRpth
with s as (
    some select with id column
), u as (
    update target_table_with_id_column as t set
        column = s.corresponding_column
        ...
    from s where t.id = s.id
    returning t.id, 'update'::text as command
), i as (
    insert into target_table_with_id_column select s.* from s left join u using (id) where u.id is null returning id, 'insert'::text as command
) select command, count(id) from i group by 1 union select command, count(id) from u group by 1
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы