摘要:导语今天在写的时候,遇到一个问题。需求是这样的,查询数据,按照评分倒序近一周访问量倒序,这样进行排序。解决办法呢,就是将条件放到中。参考资料步步深入架构总览查询执行流程解析顺序操作中与放置条件的区别中过滤条件放在和中的区别。
导语
今天在写 SQL 的时候,遇到一个问题。需求是这样的,查询数据,按照评分倒序、近一周访问量倒序,这样进行排序。问题是常规的写法,将 day >= xxx 条件放到 where 中, 如果某些数据近一周没有访问量,那么这条数据就查不出来。解决办法呢,就是将条件放到 LEFT JOIN 中。
MySQL 语句执行顺序首先先说明一个概念,MySQL 语句执行的顺序,并不是按照 SQL 语句的顺序。下面是示例 SQL
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 的执行顺序
FROMLEFT JOIN 的作用ON JOIN WHERE GROUP BY HAVING SELECT DISTINCT ORDER BY LIMIT
结果集的不同,不仅与 SQL 的优先级有关,还和 LEFT JOIN 有关
使用left join时on后面的条件只对右表有效
on是在生成临时表的时候使用的条件,不管on的条件是否起到作用,都会返回左表 (table_name1) 的行。
where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤掉。
以上是从两篇资料中摘抄的,可以很好的概括(原文链接在下方,其中都有示例)。
参考资料:步步深入:MySQL架构总览->查询执行流程->SQL解析顺序、MySQL left join操作中 on与where放置条件的区别、SQL中过滤条件放在on和where中的区别。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30027.html
摘要:如果之前对不同的执行结果没有概念,可以结合这篇文章往下看的执行顺序以下是查询的通用结构它的执行顺序如下语句里第一个被执行的总是子句对左右两张表执行笛卡尔积,产生第一张表。 0 索引 JOIN语句的执行顺序 INNER/LEFT/RIGHT/FULL JOIN的区别 ON和WHERE的区别 1 概述 一个完整的SQL语句中会被拆分成多个子句,子句的执行过程中会产生虚拟表(vt)...
阅读 2545·2023-04-26 01:44
阅读 2557·2021-09-10 10:50
阅读 1410·2019-08-30 15:56
阅读 2250·2019-08-30 15:44
阅读 512·2019-08-29 11:14
阅读 3416·2019-08-26 11:56
阅读 3018·2019-08-26 11:52
阅读 908·2019-08-26 10:27