博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sqlserver之on与where条件
阅读量:5227 次
发布时间:2019-06-14

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

  在进行两个表乃至多个表进行联接时需要on条件进行匹配,很多时候我们会对过滤条件放在on还是where中心存疑惑。一般来讲,在外联接中on是两个表进行关联的匹配条件,在该条件匹配下会生成一个虚拟表。

  如:left join在根据on中的条件联接表时,即使左边的表(保留表)和右边的表(非保留表)存在不匹配项(即外部行),联接后的结果也会完整保留左边表的内容,只是外部行在非保留表中的列都是NULL,即left join得到的结果包括内部行(匹配项)和外部行(不匹配项)。而where子句是在from子句进行处理的,这个时候如果在where子句中指定过滤条件,将得到最终需要的结果。

  一言概之,on子句过滤条件不是最终的,而where子句过滤条件却是最终的!

  两个表的基本信息分别如下(顾客信息表/订单表):

  当查询要求为:返回在2007年2月12日下过订单的客户,以及他们的订单,同时也返回在2007年2月12日没有下过订单的客户。

select c.custid,c.companyname,o.orderid,o.orderdatefrom sales.customers as cleft join sales.orders as oon o.custid=c.custidand o.orderdate='20070212';
View Code

  根据红线框的结果,将过滤条件orderdate='20070212'放在on子句中返回了在这一天下过订单的客户以及没有下订单的客户,同时注意到上图右下脚结果集总共有91行,也就是外联结的结果留下的是保留表的数据,未匹配的非保留表列值为NULL。

  如果查询的要求前半句不变,后半句改为“不返回在2007年2月12日没有下过单的客户”。这时就需要将过滤条件orderdate=‘20070212’放在where子句中。最终的结果只有在当天没下单的客户数据。

select c.custid,c.companyname,o.orderid,o.orderdatefrom sales.customers as cleft join sales.orders as oon o.custid=c.custidwhere  o.orderdate='20070212';
View Code

 

转载于:https://www.cnblogs.com/wxyz94/p/9407933.html

你可能感兴趣的文章
uva 10137 The trip
查看>>
Count Numbers
查看>>
编写高质量代码改善C#程序的157个建议——建议110:用类来代替enum
查看>>
网卡bond技术
查看>>
UITabbarController的UITabbarItem(例:"我的")点击时,判断是否登录
查看>>
UNIX基础知识之输入和输出
查看>>
【洛谷 P1666】 前缀单词 (Trie)
查看>>
数据库锁机制及乐观锁,悲观锁的并发控制
查看>>
图像处理中双线性插值
查看>>
RobHess的SIFT代码解析之RANSAC
查看>>
03 线程池
查看>>
201771010125王瑜《面向对象程序设计(Java)》第十三周学习总结
查看>>
手机验证码执行流程
查看>>
python 基础 ----- 变量
查看>>
设计模式课程 设计模式精讲 2-2 UML类图讲解
查看>>
Silverlight 的菜单控件。(不是 Toolkit的)
查看>>
:hover 鼠标同时触发两个元素变化
查看>>
go语言学习十三 - 相等性
查看>>
Idea 提交代码到码云(提交到github也大同小异)
查看>>
c#连接excel2007未安装ISAM解决
查看>>