暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Mysql查询执行顺序

AI技术研习社 2020-11-15
18

关注我,每天学习一点点,每天进步一点点!


前面,已经介绍了Mysql安装和建库,以及数据类型,在介绍建表之前,先来聊聊查询,而查询中最重要的不是写多少SQL,而是先搞清楚SQL查询的执行顺序,先搞清楚执行顺序,那写SQL才会有下笔如有神的感觉!


先来看看,一个完整的SQL查询:


    SELECT DISTINCT column, AGG_FUNC(column_or_expression)
    FROM mytable
    JOIN another_table
    ON mytable.column = another_table.column
    WHERE constraint_expression
    GROUP BY column
    HAVING constraint_expression
    ORDER BY column ASC/DESC
    LIMIT count OFFSET COUNT;
    复制



    一个查询SQL的执行总是先从数据里按条件选出数据,然后对这些数据再次做一些整理处理,按要求返回成结果,让结果尽可能是简单直接的。


    因为一个查询SQL由很多部分组成,所以搞清楚这些部分的执行顺序还挺重要的,这有助于我们更深刻的理解SQL执行过程。


    查询执行顺序如下:


    1. FROM 和 JOINs

    FROM 或 JOIN会第一个执行,确定一个整体的数据范围. 如果要JOIN不同表,可能会生成一个临时Table来用于 下面的过程。总之第一步可以简单理解为确定一个数据源表(含临时表) 。


    2. WHERE

    我们确定了数据来源 WHERE 语句就将在这个数据源中按要求进行数据筛选,并丢弃不符合要求的数据行,所有的筛选col属性 只能来自FROM圈定的表. AS别名还不能在这个阶段使用,因为可能别名是一个还没执行的表达式 。


    3. GROUP BY

    如果你用了 GROUP BY 分组,那GROUP BY 将对之前的数据进行分组,统计等,并将是结果集缩小为分组数.这意味着 其他的数据在分组后丢弃。


    4. HAVING

    如果你用了 GROUP BY 分组, HAVING 会在分组完成后对结果集再次筛选。AS别名也不能在这个阶段使用。


    5. SELECT

    确定结果之后,SELECT用来对结果col简单筛选或计算,决定输出什么数据。


    6. DISTINCT

    如果数据行有重复DISTINCT 将负责排重。


    7. ORDER BY

    在结果集确定的情况下,ORDER BY 对结果做排序。因为SELECT中的表达式已经执行完了。此时可以用AS别名。


    8. LIMIT OFFSET

    最后 LIMIT 和 OFFSET 从排序的结果中截取部分数据。


    结论

    不是每一个SQL语句都要用到所有的句法,但灵活运用以上的句法组合和深刻理解SQL执行原理将能在SQL层面更好的解决数据问题,而不用把问题 都抛给程序逻辑。


     声明:【原创文章,若要转载,请联系作者,谢谢!】



    “动动手指,点亮小花分享给更多人吧!”
    文章转载自AI技术研习社,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

    评论