下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
SQL语句中leftjoin后用on还是where,区别大了!前天写SQL时本想通过AleftBjoinonand后面的条件来使查出的两条记录变成一条,奈何发现还是有两条。后来发现joinonand不会过滤结果记录条数,只会根据and后的条件是否显示B表的记录,A表的记录一定会显示。不管and后面的是A.id=1还是B.id=1,都显示出A表中所有的记录,并关联显示B中对应A表中id为1的记录或者B表中id为1的记录。运行sql:select
*
from
student
s
left
join
class
c
on
s.classId=c.id
order
by
s.id运行sql:select
*
from
student
s
left
join
class
c
on
s.classId=c.id
and
="张三"
order
by
s.id运行sql:select
*
from
student
s
left
join
class
c
on
s.classId=c.id
and
="三年级三班"
order
by
s.id数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。搜索公众号后端架构师后台回复“架构整洁”,获取一份惊喜礼包。在使用leftjion时,on和where条件的区别如下:1、on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有leftjoin的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。假设有两张表:表1:tab2表2:tab2两条SQL:1、select
*
form
tab1
left
join
tab2
on
(tab1.size
=
tab2.size)
where
=’AAA’2、select
*
form
tab1
left
join
tab2
on
(tab1.size
=
tab2.size
and
=’AAA’)第一条SQL的过程:1、中间表on条件:tab1.size
=
tab2.size2、再对中间表过滤where条件:=’AAA’第二条SQL的过程:1、中间表on条件:tab1.size
=
tab2.size
and
=’AAA’(条件不为真也会返回左表中的记录)其实以上结果的关键原因就是leftjoin,rightjoin,fulljoin的特殊性,不管on上的条件是否为真都会返回left或right表中的记录,full则具有lef
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 幼儿教师职业目标规划
- 常用容量分析操作实验报告总结
- 幼儿园校内安全形势分析报告
- 幼儿园小班班级管理计划书
- 幼儿膳食营养分析总结与反思
- 幼儿园学前班教学计划
- 幼儿园活动观察分析与反思
- 小学美术课题研究开题报告
- 幼儿园艺术领域分析与反思总结
- 新式茶饮相关行业项目操作方案
- 2022年人工智能知识考试复习题库500题(含各题型)
- 第2-3课时主题阅读:探秘亚欧大陆最北点
- 石榴花开别样红籽籽同心一家亲民族团结一家亲主题班会课件
- 2023年广东省3+证书高职高考数学试卷(真题)及参考答案
- 童年的回忆 完整版课件
- 气力输送计算
- 社会认同理论
- DB4413∕T 19-2020 惠州市建筑二次供水工程设计、施工及验收规范
- 危房封条格式
- 外周血异型淋巴细胞和鉴别课件(PPT 27页)
- ViewSpecpro预处理光谱数据步骤
评论
0/150
提交评论