mysql - SQL中on和where的疑问。
ringa_lee
ringa_lee 2017-04-17 13:26:37
[MySQL讨论组]

最近在复习Mysql时,突然对where和左右连接的on产生了疑问,主要体现在以下问题,请大家不吝指正:

SELECT * FROM user LEFT JOIN order ON user.id = order.user_id
SELECT * FROM user,order WHERE user.id = order.user_id

  1. whereon都是在表笛卡尔积后在进行筛选的么?

  2. 如果第一项成立的话,whereon的筛选策略是不一样的,因为where会根据等式严格执行筛选,on则会根据左连接或者右连接来执行筛选,我描述的对不对?

  3. 假设还是第一项成立,那么使用自然连接左连接执行效率都应该是一样的吧,因为都是先笛卡尔积,也就不存在什么效率问题了吧。

以上三个问题,希望能分别给出意见,谢谢大家。

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
黄舟
  1. 是的。

  2. 是的。where相当于inner join。

  3. 理论上一样。实际上你可以看一下执行秒数。

巴扎黑

第一项不成立

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号