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结合,这样就可以匹配含有不匹配列名的表.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值