【MySQL必知必会】学习笔记Day8

【MySQL必知必会】学习笔记Day8&1.31&D17章&P113-118页

15、组合查询

(1)组合查询

  • 有两种基本情况,其中需要使用组合查询
    • 在单个查询中从不同的表返回类似结构的数据;
    • 对单个表执行多个查询,按单个查询返回数据。

注:多数情况下,组合相同表的两个查询完成的工作与具有多个WHERE子句条件的单条查询完成的工作相同。换句话说,任何具有多个WHERE子句的SELECT语句都可以作为一个组合查询给出

(2)创建组合查询

  • 可用UNION操作符来组合数条SQL查询

① 使用UNION

  • eg:需要价格小于等于5的所有物品的一个列表,而且还想包括供应商1001和1002生产的所有物品(不考虑价格)
    1. 分着单条查询
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);
    1. 组合查询
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);
    1. 使用多条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

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