MySQL 查询条件放置 on 和 where 的区别

导语

今天在写 SQL 的时候,遇到一个问题。需求是这样的,查询数据,按照评分倒序、近一周访问量倒序,这样进行排序。问题是常规的写法,将 day >= xxx 条件放到 where 中, 若是某些数据近一周没有访问量,那么这条数据就查不出来。解决办法呢,就是将条件放到 LEFT JOIN 中。html

MySQL 语句执行顺序

首先先说明一个概念,MySQL 语句执行的顺序,并非按照 SQL 语句的顺序。下面是示例 SQLsql

SELECT DISTINCT
    < select_list >
FROM
    < left_table > < join_type >
JOIN < right_table > ON < join_condition >
WHERE
    < where_condition >
GROUP BY
    < group_by_list >
HAVING
    < having_condition >
ORDER BY
    < order_by_condition >
LIMIT < limit_number >

下面是 SQL 的执行顺序架构

FROM <left_table>
ON <join_condition>
<join_type> JOIN <right_table>
WHERE <where_condition>
GROUP BY <group_by_list>
HAVING <having_condition>
SELECT 
DISTINCT <select_list>
ORDER BY <order_by_condition>
LIMIT <limit_number>

LEFT JOIN 的做用

结果集的不一样,不只与 SQL 的优先级有关,还和 LEFT JOIN 有关ssh

使用left join时on后面的条件只对右表有效.net

  • on是在生成临时表的时候使用的条件,无论on的条件是否起到做用,都会返回左表 (table_name1) 的行。
  • where则是在生成临时表以后使用的条件,此时已经无论是否使用了left join了,只要条件不为真的行,所有过滤掉。

以上是从两篇资料中摘抄的,能够很好的归纳(原文连接在下方,其中都有示例)。code


参考资料:步步深刻:MySQL架构总览->查询执行流程->SQL解析顺序MySQL left join操做中 on与where放置条件的区别SQL中过滤条件放在on和where中的区别htm

相关文章
相关标签/搜索