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

Подскажите, если возможность в запросе вида insert into table_name (f1,

f2, f3...) values (v1,v2,v3...) on conflict (f1) do update set f2=v2, f3=v3
выполнять update только не null значениями?

Например, v2 было null, а v3 нет, в момент обновления для записи прилетело v2 не null, а v3 null?
Есть ли возможность каких либо проверок, чтобы не занулять внесенные ранее значения?

13 ответов

21 просмотр

coalesce

Vladimir-Lepeshko Автор вопроса
Ilya Anfimov
coalesce

спасибо, изучу👍

Vladimir-Lepeshko Автор вопроса
Ilya Anfimov
coalesce

насколько я понял нужно обернуть каждое значение в coalesce? Что то не работает или я неправильно делаю, можешь добавить чуть деталей к подсказке?)

Vladimir Lepeshko
насколько я понял нужно обернуть каждое значение в...

Нужно. Вместе с "дефолтным" старым значением.

Vladimir-Lepeshko Автор вопроса
Kairat
set f2 = coalesce(v2, f2), f3 = coalesce(v3, f3)

ааа, сейчас попробую!)

Kairat
set f2 = coalesce(v2, f2), f3 = coalesce(v3, f3)

Я бы сказал set f2=coalesce(excluded.f2, table_name.f2), ...

Vladimir-Lepeshko Автор вопроса
Ilya Anfimov
Я бы сказал set f2=coalesce(excluded.f2, table_nam...

Вариант status = coalesce(status, 'done') возвращает ошибку error: column reference "status" is ambiguous Вариант status = coalesce((select status from items where account_id=23456), 'done') работает, но у меня около 8 - 10 таких полей и select в каждом выглядит очень нагроможденно Может я снова неверно указываю аргументы в функции?

Vladimir Lepeshko
Вариант status = coalesce(status, 'done') возвра...

Ну, попробуйте теперь именно так, как я посоветовал.

Vladimir-Lepeshko Автор вопроса
Ilya Anfimov
Ну, попробуйте теперь именно так, как я посоветова...

Сработал status = coalesce(table_name.status, 'done') Спасибо за помощь)

Vladimir Lepeshko
Сработал status = coalesce(table_name.status, 'don...

Я бы сказал, что скорее надо наборот. Но, в общем, тут сами решайте.

вы уверены, что используете верный status? Выглядит так, будто меняете значение на то же самое значение

Vladimir-Lepeshko Автор вопроса
Kairat
вы уверены, что используете верный status? Выгляди...

Создание записи специфично, тут уже много деталей по приложению. Мне важен был сам принцип - не занулять значения ни в коем случае) Далее, уже буду разбираться в конкретных кейсах задачи

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

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

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Карта сайта