SQL语句中 left join 后用 on 还是 where区别大了_第1页
SQL语句中 left join 后用 on 还是 where区别大了_第2页
SQL语句中 left join 后用 on 还是 where区别大了_第3页
SQL语句中 left join 后用 on 还是 where区别大了_第4页
SQL语句中 left join 后用 on 还是 where区别大了_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论