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;

  • 相关阅读:
    CF1029C Maximal Intersection 暴力枚举
    2018中国大学生程序设计竞赛
    php远程抓取(下载)文件到本项目指定目录中
    FCKEditor添加字体
    UCenter 与 DIscuz 通信失败的解决方法
    运用php函数mkdir创建多级目录
    PHP 数组函数-数组排序
    php登陆ssh执行命令
    php定时执行任务的几个方法
    PHP Yii框架中使用smarty模板
  • 原文地址:https://www.cnblogs.com/shay-zhangjin/p/7906831.html
Copyright © 2011-2022 走看看