FROM Продукты
WHERE Жиры IS NULL
UNION
SELECT Продукт
FROM Состав
WHERE Блюдо = 1;
Результат объединения
Из этого простого примера видно, что избыточные дубликаты всегда исключаются из результата UNION. Поэтому, хотя в рассматриваемом примере Помидоры(11), Зелень(12) и Яблоки(15) выбираются обеими частями из двух составляющих предложения SELECT, в окончательном результате они появляются только один раз.
Предложением с UNION можно объединить любое число запросов. Так, к предыдущему запросу можно добавить (перед точкой с запятой) конструкцию
UNION
SELECT Продукт
FROM Продукты
WHERE Ca < 250;
позволяющую добавить к списку продуктов Масло, Рис, Мука и Кофе. Однако тот же результат можно получить простым изменением фразы WHERE первой части исходного запроса
WHERE Жиры = 0 OR Ca < 250;
UNION и устранение дубликатов.
UNION будет автоматически исключать дубликаты строк из вывода. Это нечто несвойственное для SQL, так как одиночные запросы обычно содержат DISTINCT чтобы устранять дубликаты. Например, запрос
Пример 39.
SELECT Блюдо, Количество_порций
FROM Заказы
WHERE Дата = '2011-01-02'
UNION
SELECT Блюдо, Количество_порций