• 09_MySQL DQL_SQL99标准中的多表查询(外连接)


    # 二、外连接
    /*
    场景:查询值在1个表中出现,在另外1个表中没有出现

    特点:
    0、也是两张表的字段拼接,分为主表和从表
    1、外连接的结果,将显示主表中的所有记录行
        如果连接字段在从表中有记录,则显示匹配值
        如果连接字段在从表中没有记录,则显示null
    2、外连接的结果 = 内连接结果 + 主表中有,从表中填充null的记录

    3、左外连接,left左边的为主表
       右外连接,right右边的为主表

    4、全外连接 = 等值内连接+表1中有表2中没有+表2中有表1中没有(null天成)
    MySQL不支持SQL99标准中的全外连接
    */

    USE girls;

    #案例1:查询男朋友不在男神表中的女神表
    #1 先查看left join的结果
    SELECT b.name, bo.*
    FROM beauty AS b
    LEFT JOIN boys AS bo
    ON b.`boyfriend_id` = bo.`id`;

    #2 过滤出id=NULL的记录
    SELECT b.name
    FROM beauty AS b
    LEFT JOIN boys AS bo
    ON b.`boyfriend_id` = bo.`id`
    WHERE bo.`id` IS NULL; #使用bo的主键id来做过滤,为null的肯定是没有匹配到的

    #3 使用right join完成同样功能
    SELECT b.name
    FROM boys AS bo
    RIGHT JOIN beauty AS b
    ON bo.`id` = b.`boyfriend_id`
    WHERE bo.`id` IS NULL;

    SELECT bo.*, b.*
    FROM boys AS bo
    LEFT JOIN beauty AS b
    ON bo.`id` = b.`boyfriend_id`;


    USE myemployees;
    #案例1:查询没有员工的部门
    SELECT d.department_name, d.`department_id`, e.`last_name`
    FROM departments AS d
    LEFT JOIN employees AS e
    ON d.`department_id` = e.`employee_id`
    WHERE e.`last_name` IS NULL;

  • 相关阅读:
    铬族元素
    Linux下安装虚拟环境
    Flask之路由系统
    Flask之CSRF
    【原创】关于Azure Storage Simulator 不能启动的问题
    今天终于搞清楚了正则表达式
    模型权重的保存与加载 回调函数的使用
    卷积神经网络结构
    滑动窗口与R-CNN
    模型权重记录与恢复
  • 原文地址:https://www.cnblogs.com/shay-zhangjin/p/7906831.html
Copyright © 2020-2023  润新知