博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sql 183. 从不订购的客户
阅读量:6956 次
发布时间:2019-06-27

本文共 1169 字,大约阅读时间需要 3 分钟。

某网站包含两个表,Customers 表和 Orders 表。编写一个 SQL 查询,找出所有从不订购任何东西的客户。

Customers 表:

+----+-------+| Id | Name  |+----+-------+| 1  | Joe   || 2  | Henry || 3  | Sam   || 4  | Max   |+----+-------+

Orders 表:

+----+------------+| Id | CustomerId |+----+------------+| 1  | 3          || 2  | 1          |+----+------------+

例如给定上述表格,你的查询应返回:

+-----------+| Customers |+-----------+| Henry     || Max       |+-----------+
select customers.name as Customers from customers left join  orders on customers.id=orders.customerid where orders.customerid is null

这个sql用了左连接 和 is null语法。

左连接的这种用法学习到了。如果右边的表没有满足on 后条件的值就会为null

下面贴一个左连接执行顺序的讲解

执行顺序:先执行on and条件,再执行where条件

具体是:首先根据on and条件过滤出满足条件的右侧表记录,然后根据关联字段,左侧表再与过滤出的右侧表记录进行连接,

满足关联字段相等,则返回左侧表和右侧表字段信息;若不满足,则返回左侧表字段信息,右侧表字段则显示NULL

连接出的结果则存入临时表中。最后where条件是对临时表中的数据进行过滤。

左连接:Left join,以左侧表为主,不管on条件是否满足条件,左侧表的所有记录都会返回。

换句说:on and后面的条件对左侧表没有过滤作用,即使加上对左侧表的过滤,也不起作用。

on后面的条件对右侧表的过滤起作用。where条件则对左连接后的临时表数据进行筛选。

以例子说明:

select * from A left join B

on A.ID = B.ID and B.NAME = '连接' and A.NAME = ‘左连接’

where NAME = '左连接'

on and后面的条件:B.NAME对B表有过滤作用,A.NAME对A表不起过滤作用

where后面的条件:则是对左连接出的临时表数据进行过滤

转载于:https://www.cnblogs.com/wangshaowei/p/11074665.html

你可能感兴趣的文章
正则表达式
查看>>
关于直播视频格式和浏览器兼容性历史的来龙去脉
查看>>
是的,InfoQ正在招聘技术编辑!跟对的人,一起做喜欢的事!
查看>>
vue2+vue-cli,dis文件加载出错解决方案
查看>>
立下“去O”Flag的AWS,悄悄修炼了哪些内功?
查看>>
关于团队建设,穆帅能教我们什么?
查看>>
2019 SRE 调查报告:事故处理是主要工作,SRE 压力山大
查看>>
xpath学习
查看>>
Java工程师的成长路线图是什么?
查看>>
JavaOne 2016——首日亮点
查看>>
EDU_BOOK 开发总结
查看>>
简单的支持网页画框拖拽缩放功能的js插件
查看>>
使用 ES2015 开发 Angular1.x 应用指南
查看>>
密码学协议 门限
查看>>
true or false in JavaScript
查看>>
Android学习笔记6:使用Intent1
查看>>
js实现继承的几种方式
查看>>
[LintCode/LeetCode] Two Strings are Anagrams/Valid Anagram
查看>>
Consul入门03 - 注册服务
查看>>
[Centos]necessary tools for newbie
查看>>