概述
SQL语句中 left join 后用 on 还是 where
- SQL语句中 left join 后用 on
- SQL语句中 left join 后用where
- demo
数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。
SQL语句中 left join 后用 on
join on and 不会过滤结果记录条数,on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录,只会根据and后的条件是否显示 B表的记录,A表的记录一定会显示。
SQL语句中 left join 后用where
where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。
demo
目前有两张表
用户表
用户角色表
我们先只使用 left join ,共13条记录,其中两个用户的roleid有值
再 left join on 后面加条件,还是13条记录,但是a表中的数据都展示出来了,不满足条件的没有展示b表的数据。
left join 后用where,共一条记录。
left join,right join,full join,不管on上的条件是否为真都会返回left或right表中的记录,full则具有left和right的特性的并集。
而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。
最后
以上就是简单诺言为你收集整理的SQL语句中 left join 后用 on 还是 whereSQL语句中 left join 后用 onSQL语句中 left join 后用wheredemo的全部内容,希望文章能够帮你解决SQL语句中 left join 后用 on 还是 whereSQL语句中 left join 后用 onSQL语句中 left join 后用wheredemo所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复