阅读目录

1、首先来谈谈什么是left join

2、再来谈谈on后面使用and和where的区别

3、总结

今天的最佳表现应该作为明天的最低要求

1、首先来谈谈什么是left join

left join即左连接,比如表1左连接表2,以左表为主,表示以表1为主,关联上表2的数据,查询出来的结果显示左表的所有数据,然后右边显示的是和左表有交集的数据

比如下面有学生表(student)和教师表(teacher),将教师表的主键作为学生表的外键,此外建可为空,即有的学生可能暂时还没有分配到教师。表结构如下所示

学生表(student)

教师表(teacher)

现在假设需要查询出所有学生的aid、name以及教师的name,有没有分配教师的学生都需要查询出来,以便给没有分配教师的学生进行教师分配,这个SQL该怎么写呢?如下所示

SELECT s.aid,s.name, t.name teacher_name
    FROM student s
    LEFT JOIN teacher t ON s.teacher_aid = t.aid

这样就查询出了所有学生的信息,包括未分配教师的学生,student表作为左表,teacher作为右表,查询出student表的所有数据以及和teacher表有交集的数据,这就是左连接(left join)
2、再来谈谈on后面使用and和where的区别

假设现在student表里面的数据如下

现在有一个接口的要求是查询出目前在读(is_read  = 1)的学生的aid、name和教师的name,这个SQL该怎么写呢?如下所示

(1)、第一种情况,在on后面使用and,SQL 如下所示

SELECT s.aid,s.name, t.name teacher_name
    FROM student s
    LEFT JOIN teacher t ON s.teacher_aid = t.aid
    AND s.is_read = 1

查询结果是这样的

很显然根据上面student的数据来看,这个SQL语句查询的结果中包含了is_read = 0的数据,而接口要求的是查询出is_read  = 1的数据,这个SQL无法查询出正确的数据。

(2)、第二种情况,在on后面使用where,SQL 如下所示

SELECT s.aid,s.name, t.name teacher_name
    FROM student s
    LEFT JOIN teacher t ON s.teacher_aid = t.aid
    WHERE s.is_read = 1

查询结果是这样的

很显然根据上面的student表的数据来看,这个SQL查询出来的数据正是is_read = 1的数据,完全符合接口的要求,所以这个接口查询的数据是正确的。
3、总结

根据上面的例子相信有的人已经猜出了这两者的区别,我这里做个总结

在on后面使用and

如果and语句是对左表进行过滤,那么无论这个过滤条件是真是假都不起作用,左表的记录会全部返回
          如果and是对右表进行过滤,那么左表会与过滤后的右表进行左连接,左表数据依旧全部返回

在on后面使用where

where是对连接后的结果集(临时表)进行过滤的,此时的left join已经不起作用,条件不为真的数据就全部过滤掉
————————————————
版权声明:本文为CSDN博主「小小花卷」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_43776514/article/details/115530127

on后面使用and和where的区别相关推荐

  1. RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别

    1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...

  2. C++ 笔记(28)— C++ 中 NULL和 nullptr 的区别

    最近看公司代码的时候发现在判断指针是否为空的时候,有的时候用的是 NULL, 有的时候用的是 nullptr 感觉很奇怪,好奇心驱使我查了下两者的区别,发现还是有很多细节需要学习的. 1. NULL ...

  3. gcc 和 g++ 的联系和区别,使用 gcc 编译 c++

    GCC 编译器已经为我们提供了调用它的接口,对于 C 语言或者 C++ 程序,可以通过执行 gcc 或者 g++ 指令来调用 GCC 编译器. 实际使用中我们更习惯使用 gcc 指令编译 C 语言程序 ...

  4. Python2 与 Python3 区别

    Python2.x 与 Python3.x 区别 1. print 函数 Python2 中 print 是语句(statement),Python3 中 print 则变成了函数.在 Python3 ...

  5. Docker 入门系列(1)- 初识容器,镜像、容器、仓库的区别

    Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...

  6. HTTP 协议入门 — (TCP/IP协议族、通信传输流、URI 与 URL 的区别、Cookie 状态管理、HTTP 支持的方法、状态码类别、HTTP 首部字段)

    TCP/IP协议族 在介绍 HTTP 协议之前,我们先对 TCP/IP 协议族有个大概的了解,TCP/IP 协议从上到下主要分为应用层.传输层.网络层和数据链路层,各层的主要功能如下表所示: 协议层 ...

  7. python二进制打开(rb)和文本格式打开(r)什么区别?

    使用 open() 函数以文本格式打开文件和以二进制格式打开文件,唯一的区别是对文件中换行符的处理不同. 在 Windows 系统中,文件中用 "\r\n" 作为行末标识符(即换行 ...

  8. python中__dict__与dir()区别

    前言 Python下一切皆对象,每个对象都有多个属性(attribute),Python对属性有一套统一的管理方案. __dict__与dir()的区别: dir()是一个函数,返回的是list: _ ...

  9. java和C#面向对象的区别

    问题:C#中的构造函数和java的构造函数一样吗? 答: .net的项目中,写实体Entity属性时,经常会为每一个属性写一对get和set方法,在用到这个实体或是一个类时,通过new实例化一个对象, ...

  10. 判别模型和生成模型的区别

    20210703 https://www.zhihu.com/question/20446337 机器学习"判定模型"和"生成模型"有什么区别? 重点 http ...

最新文章

  1. 过来人经验:实验室没人教你怎么办?
  2. SAP RFC通信模式
  3. qt 文件 时间 倒序排列_win7电脑敬业签便签软件分类标签里的内容如何按提醒时间排列?...
  4. python神经网络多元函数_阿里达摩院推荐的最新400集python教程,据说懂中文就能上手...
  5. mysql main函数_关于main()函数的小技巧
  6. vue 关闭弹如何销毁子组件_vue中的eventBus会产生内存泄漏吗
  7. c盘扩展卷功能只能向右扩展_信用风险管理:功能扩展和选择
  8. js遍历Object所有属性
  9. 【转】算法导论学习笔记 一 分治算法
  10. 从另一个角度看大数据量处理利器:布隆过滤器
  11. 活动子项父项的复杂CSS选择器[重复]
  12. 01-操作数组的方法
  13. 反射ModelToDto
  14. 如何通过修改注册表来限定Win10 PIN的最小位数
  15. c语言的编译器还真是不好理解...
  16. Network Delay Time
  17. vue项目生成二维码功能使用QRCode(接入微信和支付宝支付接口)
  18. 创建型模式大全(Java讲解)
  19. 华硕天选一代无线网卡断网
  20. Python+Matplotlib绘制饼状图模拟南丁格尔玫瑰图

热门文章

  1. 互联网创业公司融资、产品、运营快速迭代和人才模式总结
  2. adb shell 模拟器 关闭\打开WIFI
  3. CoAP协议的常用开源代码实现
  4. 有好看的女生用的黑色壁纸吗?
  5. 新近出现的恶意软件:Visal.B
  6. 凌云驭势 亚马逊云科技开启re:Invent中国行
  7. 苹果电脑/macbookpro 拔出电源充电器但还是显示充电的解决办法
  8. 怎样淡化疤痕留下的色素沉着
  9. java-php-python-ssm-兴澜幼儿园管理系统-计算机毕业设计
  10. 实验2《MySQL数据库原理与应用》