关于Mysql中ON与Where区分问题详解
今天工作的时候编写了一个SQL,大家一起来看一下
LEFT JOIN
user_message msg
ON user.id = msg.user_id AND user.name = ‘张三’
我们有一张user表
我们还有一张user_message表
我们履行上面的SQL后,查询结果以下
其实不如我们所想的,只出现张三的结果,这是为何呢?
经过我的整理发现查询是以下缘由
关联的时候ON条件是在合并两张表构成临时表前进行的条件挑选,所以在使用 JOIN 关键字进行关联的时候,特别是左关联或右关联的时候,不要使用 字段 = '定值' 这类挑选方式
在内关联(inner join)中,Mysql判断 字段 = '定值' 如果为false,会被挑选掉,如果为true,则会正确显示数据。
在左关联(left join)中,Mysql判断 字段 = '定值' 如果为false,会返回左表的数据,如果为true,则会正确显示显示数据。
在右关联(right join)中,Mysql判断 字段 = '定值' 如果为false,会返回右表的数据,如果为true,则会正确显示显示数据。
所以我上述的SQL会返回张三的全部数据,除张三外的所有数据只会返回左表数据,右表全部为null,不管会不会可以匹配到。
where是在临时表创建成功后,再次对临时表进行挑选的,所以此时我们可以对关联后的数据随便进行挑选。
区分总结:
先履行on,后履行where;on是建立关联关系,where是对关联关系的挑选。
比如两个表进行left join连接查询结果,where会对查询的结果进行过滤, on会返回驱动表的所有数据。
left join依照条件关联,不论是不是为真,都返回左侧表的数据。
总结
到此这篇关于关于Mysql中ON与Where区分问题的文章就介绍到这了,更多相关Mysql ON与Where区分内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!
文章来源:丸子建站
文章标题:关于Mysql中ON与Where区分问题详解
https://www.wanzijz.com/view/61321.html