最近在复习Mysql时,突然对where
和左右连接的on
产生了疑问,主要体现在以下问题,请大家不吝指正:
SELECT * FROM
user
LEFT JOINorder
ON user.id = order.user_id
SELECT * FROMuser
,order
WHERE user.id = order.user_id
where
和on
都是在表笛卡尔积
后在进行筛选的么?如果第一项成立的话,
where
和on
的筛选策略是不一样的,因为where
会根据等式严格执行筛选,on
则会根据左连接
或者右连接
来执行筛选,我描述的对不对?假设还是第一项成立,那么使用
自然连接
和左连接
的执行效率
都应该是一样的吧,因为都是先笛卡尔积,也就不存在什么效率问题了吧。
以上三个问题,希望能分别给出意见,谢谢大家。
是的。
是的。where相当于inner join。
理论上一样。实际上你可以看一下执行秒数。