SQL中的组合查询概述

--组合查询
--什么是组合查询?  SQL允许执行多个查询(即有多条select语句),并将结果作为一个查询结果返回,这些组合查询通常称为组合查询
--什么情况下需要用到组合查询?  1.在一个查询中从不同表返回结构数据 2.对一个表执行多个查询,按一个查询返回数据
--注意:任何具有多个WHERE字句的SELECT语句都可以当做一个组合查询

--1.创建组合查询
SELECT cust_name,cust_contact,cust_email
FROM Customers
WHERE cust_state IN('IN','IL','MI')
UNION 
SELECT cust_name,cust_contact,cust_email
FROM Customers
WHERE cust_name='Fun4All'
ORDER BY cust_name

 --使用多条WHERE字句而不是UNION的相同查询
 SELECT cust_name,cust_contact,cust_email
FROM Customers
WHERE cust_state IN('IN','IL','MI')
    OR  cust_name='Fun4All'
--结果一样
--区别:对于较复杂的过滤条件,或者从多个表中检索数据的情形,使用UNION可能会使得处理更简单

--UNION规则
--1. UNION必须由两天或两条以上的SELECT语句组成。
--2. UNION中的 每个查询必须包含相同的列、表达式或聚集函数。
--3. 列数据类型必须兼容。
--4. 使用UNION时,重复的行会被自动取消(事实上多个WHERE语句也会),但是可以用UNION ALL而不是UNION来避免取消重复的行。
--5. 若要对组合查询的结果用ORDER BY进行排序,则只能使用一条ORDER BY字句,且必须位于最后一条SELECT语句后面。
--6. UNION在组合多个表的数据时可以与别名AS结合,这样就可以匹配含有不匹配列名的表.



你可能感兴趣的:(数据库)