【MySQL必知必会】学习笔记Day8&1.31&D17章&P113-118页
15、组合查询
(1)组合查询
- 有两种基本情况,其中需要使用组合查询
- 在单个查询中从不同的表返回类似结构的数据;
- 对单个表执行多个查询,按单个查询返回数据。
注:多数情况下,组合相同表的两个查询完成的工作与具有多个WHERE子句条件的单条查询完成的工作相同。换句话说,任何具有多个WHERE子句的SELECT语句都可以作为一个组合查询给出
(2)创建组合查询
- 可用UNION操作符来组合数条SQL查询
① 使用UNION
- eg:需要价格小于等于5的所有物品的一个列表,而且还想包括供应商1001和1002生产的所有物品(不考虑价格)
-
- 分着单条查询
SELECT vend_id,prod_id,prod_price
FROM products
WHERE prod_price<=5;
SELECT vend_id,prod_id,prod_price
FROM products
WHERE vend_id IN(1001,1002);
-
- 组合查询
SELECT vend_id,prod_id,prod_price
FROM products
WHERE prod_price<=5
UNION
SELECT vend_id,prod_id,prod_price
FROM products
WHERE vend_id IN(1001,1002);
-
- 使用多条where语句达到相同查询效果
SELECT vend_id,prod_id,prod_price
FROM products
WHERE prod_price<=5
OR vend_id IN(1001,1002);
② UNION规则
- UNION必须由两条或两条以上的SELECT语句组成,语句之间用关键字UNION分隔(如果组合4条SELECT语句,将要使用3个UNION关键字)
- UNION中的每个查询必须包含相同的列、表达式或聚集函数(不过各个列不需要以相同的次序列出)。
- 列数据类型必须兼容:类型不必完全相同,但必须是DBMS可以隐含地转换的类型(例如,不同的数值类型或不同的日期类型)。
③ 包含或取消重复的行
- UNION会默认去除重复的行,使用UNION ALL,则不取消重复行
SELECT vend_id,prod_id,prod_price
FROM products
WHERE prod_price<=5
UNION ALL
SELECT vend_id,prod_id,prod_price
FROM products
WHERE vend_id IN(1001,1002);
④ 对组合查询结果排序
- 在用UNION组合查询时,只能用一条ORDER BY子句,跟在最后一条SELECT之后,实际上它可以来排序所有SELECT语句返回的所有结果
SELECT vend_id,prod_id,prod_price
FROM products
WHERE prod_price<=5
UNION
SELECT vend_id,prod_id,prod_price
FROM products
WHERE vend_id IN(1001,1002)
ORDER BY vend_id,prod_price;
注:上述例子是使用的相同的表。但使用UNION的组合查询也可以应用不同的表
【MySQL必知必会】系列笔记:
【MySQL必知必会1-4章】学习笔记Day1
【MySQL必知必会5-7章】学习笔记Day2
【MySQL必知必会8-9章】学习笔记Day3
【MySQL必知必会10章】学习笔记Day4
【MySQL必知必会11-12章】学习笔记Day5
【MySQL必知必会13章】学习笔记Day6
【MySQL必知必会14-16章】学习笔记Day7