美文网首页
【MySQL必知必会】学习笔记Day8

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

作者: 小小孩儿的碎碎念 | 来源:发表于2020-01-31 23:49 被阅读0次

    【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

    相关文章

      网友评论

          本文标题:【MySQL必知必会】学习笔记Day8

          本文链接:https://www.haomeiwen.com/subject/gwcwthtx.html