Использование UNION в SQL
Я уже писал о выборке из нескольких таблиц на SQL. И там вывод одной таблицы зависил от содержимого другой. Но бывает нужно, когда требуется полная независимость вывода одной таблицы от другой. Всё, что хочется - это просто в одном запросе вытащить записи сразу из нескольких таблиц, не более того. И вот для этого используется в SQL ключевое слово UNION.
Давайте с Вами разберём SQL-запрос с использованием UNION:
SELECT `login`, `amount` FROM `employers` UNION SELECT `login`, `amount` FROM `staff`;
Данный запрос вернёт логины и суммы на счетах всех работодателей и сотрудников некоего сайта. То есть данные были в разных таблицах, но их схожесть позволяет вывести их сразу. Отсюда, кстати, идёт правило использования UNION-запросов: число и порядок полей должно совпадать во всех частях запроса.
Таких UNION-частей может быть очень много, но самое главное после последнего UNION надо обязательно поставить точку с запятой.
Ещё одной хорошей особенностью UNION является отсутствие повторений. Например, если один и тот же человек находится и среди сотрудников, и среди работодателей, разумеется, с той же самой суммой на счету, то в выборке он будет не 2 раза, а только 1, что, как правило, и требуется. А если всё-таки нужны повторения, то тогда есть UNION ALL:
SELECT `login`, `amount` FROM `employers` UNION ALL SELECT `login`, `amount` FROM `staff`;
Вот так используется достаточно простой оператор UNION в SQL-запросе, упрощающий процедуру вывода сразу из множества таблиц однотипных данных, что в свою очередь очень хорошо скажется на производительности.
-
- Михаил Русаков
Комментарии (0):
Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.