Vertica MERGE

admin

Операция MERGE позволяет объединить операции INSERT и UPDATE в БД Vertica в одну операцию. Для примера возьмем две таблицы:

CREATE TABLE target_table (id INT PRIMARY KEY, count INT);

CREATE TABLE source_table (id INT, count INT);

И вставим в них такие данные:
INSERT INTO target_table (id, count) VALUES (1,1);

INSERT INTO source_table (id, count) VALUES (1,1);

Теперь выполним MERGE данных:
MERGE INTO target_table t USING source_table s ON s.id = t.id WHEN MATCHED

THEN UPDATE SET count = s.count + t.count;
## Объединение по колонке id

Эта операция вставит данные из двух таблиц в одну. Однако, при совпадении значений id, вместо вставки будет происходить увеличение колонки count.

SELECT * FROM target_table
## Выборка результата

id | count
---+-----
1  |     2
(1 row)

## значение во второй колонке – это сумма значений из двух исходных таблиц

Останні статті

Что такое прокси-сервер: пояснение простыми словами, зачем нужны прокси

Прокси (proxy), или прокси-сервер — это программа-посредник, которая обеспечивает соединение между пользователем и интернет-ресурсом. Принцип…

21.11.2024

Что такое PWA приложение? Зачем необходимо прогрессивное веб-приложение

Согласитесь, было бы неплохо соединить в одно сайт и приложение для смартфона. Если вы еще…

19.11.2024

Как создать игру на телефоне: программирование с помощью конструктора

Повсеместное распространение смартфонов привело к огромному спросу на мобильные игры и приложения. Миллиарды пользователей гаджетов…

17.11.2024

Google Bard: эффективный аналог ChatGPT

В перечне популярных чат-ботов с искусственным интеллектом Google Bard (Gemini) еще не пользуется такой популярностью…

14.11.2024

Скрипт и программирование: что это такое простыми словами

Скрипт (англ. — сценарий), — это небольшая программа, как правило, для веб-интерфейса, выполняющая определенную задачу.…

12.11.2024

Дедлайн в разработке: что это такое простыми словами

Дедлайн (от англ. deadline — «крайний срок») — это конечная дата стачи проекта или задачи…

11.11.2024