Предложение UNION
Это еще один способ комбинирования данных запросов. С помощью предложения UNION можно объединить выходные данные нескольких запросов в единое множество строк и столбцов.
Пример: Получить сведения обо всех продавцах (Sales people) и покупателях (Customers) Лондона как данные одного запроса:
SELECT snum, sname
FROM Sales people
WHERE city = ‘London’
UNION
SELECT cnum, cname
FROM Customers
WHERE city = ‘London’;
Заметим, что ;ставится только в самом конце. Заголовки столбцов в результате отсутствуют, поскольку это объединения столбцов snum с cnum и sname с cname.
Очевидно, что реализовать UNION можно только при соблюдении определенных условий:
- Столбцы, входящие в состав выходных данных исходных запросов должны быть совместимы по объединению- union compatible. Это значит, что в каждом из запросов может быть указано одинаковое число столбцов в порядке: первый, второй, третий и т.д., причем n-й столбец одного запроса должен быть сравним с n-м столбцом другого запроса.
- Если для n-го столбца одного запроса в UNION NULL-значения запрещены, то они запрещены и для других запросов в UNION.
- Об избыточности(замечание). UNION автоматически исключает из выходных данных дублирующие строки.
- Если в UNION применяется сортировка- ORDER BY, то приходится указывать не имя столбца, а его номер.
Например: ORDER BY 3- по возрастанию.
Дата добавления: 2014-11-29; просмотров: 927;