zoukankan      html  css  js  c++  java
  • SQL:多表查询

    参考网址: https://zhuanlan.zhihu.com/p/91973413

    此次主要介绍多表查询中的三部分:合并查询结果、连接查询(交叉连接、内连接、左连接、右连接、全连接)和CASE表达式。

    1、合并查询结果

    · 含义:

    利用UNION关键字可以给出多条SELECT语句,并将结果组合成单个结果集。

    · 用法:

    自动删除重复行:SELECT语句1 UNION SELECT语句2保留重复行(不自动排序):SELECT语句1 UNION ALL SELECT语句2

    · 注意事项

    ① 合并时,两个表对应的列数和数据类型必须相同,如果列数不同,需要补足其他字符代替,如使用'或null。

    ② UNION ALL关键字语句执行时所需要的资源少,如无需删重,建议选择使用。

    2、交叉连接

    · 含义:

    交叉连接(CROSS JOIN)又可称为笛卡尔积,将左表中每一行与右表中每一行分别连接形成新记录。实际业务中运用较少,需要大量运算成本,但它是其他连接的基础。

    3、内连接查询

    · 含义:

    内连接(INNER JOIN) 使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行,组合成新记录。简而言之,查找出同时存在在不同表中的关联数据形成结果表。

    · 用法:

    SELECT 字段1,字段2,字段3,…… FROM 表名1 INNER JOIN 表名2 ON 关联条件;
    等同于
    SELECT 字段1,字段2,字段3,…… FROM 表名1,表名2 WHERE 关联条件;

    · 注意事项

    ① 如果某字段在多表中都有,则以"表名.列名"限定;

    ② 与INNER JOIN组合使用ON子句,而不是WHERE。ON和WHERE后面的指定条件相同, WHERE子句定义条件更简单明了,但某些时候会影响查询性能,而INNER JOIN语法是ANSI SQL的标准规范,能够确保不忘记连接条件。

    4、左连接查询

    · 含义:

    左连接(LEFT JOIN) 以左表为基准,将右表中的信息匹配进去,如果右表无对应值,则以空值显示。

    · 用法:

    SELECT 字段1,字段2,字段3,…… FROM 表名1 LEFT JOIN 表名2 ON 关联条件;

    若去掉左表有而右表为空的部分,在SELECT语句末尾加上"WHERE 表2.关联字段=NULL"

    5、右连接查询

    可类比左连接查询。

    · 含义:

    右连接(RIGHT JOIN) 以右表为基准,将左表中的信息匹配进去,如果左表无对应值,则以空值显示。

    · 用法:

    SELECT 字段1,字段2,字段3,…… FROM 表名1 RIGHT JOIN 表名2 ON 关联条件;

    若去掉右表有而左表为空的部分,在SELECT语句末尾加上"WHERE 表2.关联字段=NULL"

    6、全连接查询

    (由于MySQL不支持,仅作了解)

    · 含义:

    全连接(FULL JOIN)将左表和右表合并。无论哪张表的匹配字段缺少对应值,会以空值填充。

    连接关系总结:

    连接查询的应用案例:

    1. 查询所有学生的学号、姓名、选课数目和总成绩

    2. 查询平均成绩大于85分的所有学生的学号、姓名和平均成绩

    3. 查询学生的选课情况:学号,姓名,课程号,课程名称

    7、Case表达式

    用于解决复杂的查询问题,相当于进行条件判断的函数。

    · 用法:

    CASE WHEN <判断表达式> THEN <表达式>
         WHEN <判断表达式> THEN <表达式>
         WHEN <判断表达式> THEN <表达式>
         …
         ELSE <表达式>
    END;

    ELSE可以不写,默认为空值,但就完整性而言建议写上。

    应用案例:

    1. 查询出每门课程的及格人数和不及格人数。

    2. 使用分段[100-85],[85-70],[70-60],[<60]来统计各科成绩,分别统计各分段人数:课程ID和课程名称

    习题:

    习题总结:

    在习题中的第8、11、13题遇到问题。

    第8题:首先没读懂题目,“被进球”没理好思路。其次是没想过查重的问题。

    第11和13题:GROUP BY的联合分组使用掌握不好。

  • 相关阅读:
    数据字典的应用实例
    数据字典动态性能表(视图)
    MySQL exists的用法介绍
    Don’t Assume – Per Session Buffers
    MySQL 5.5: InnoDB Change Buffering
    Fixing Poor MySQL Default Configuration Values
    A quest for the full InnoDB status
    MySQL : interactive_timeout v/s wait_timeout
    Mydumper & Myloader Documentation
    InnoDB Plugin文件格式(概述)
  • 原文地址:https://www.cnblogs.com/bruce1992/p/15196049.html
Copyright © 2011-2022 走看看