zoukankan      html  css  js  c++  java
  • 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;

  • 相关阅读:
    transient关键字详解
    大话设计模式之装饰模式
    springboot读取properties(yml)的几种常用方式
    springboot整合druid数据库连接池并开启监控
    初学js的穷举思想
    循环语句
    条件分支语句
    运算符
    案例(-)
    seo搜索引擎优化
  • 原文地址:https://www.cnblogs.com/shay-zhangjin/p/7906831.html
Copyright © 2011-2022 走看看