SQL语句执行顺序

首先,要清楚在一select语句中都会用到哪些关键字:

-----------select

-----------from

-----------join

-----------where

-----------group by

-----------having

-----------order by

-----------limit

其次,要知道每执行一步就会生成一个对应的虚拟表:

明白这两点再看执行的先后顺序

1.from语句:

不管是什么SQL语句,都得先知道要在哪张表中操作吧,所以要先执行form语句。然后会生成##虚拟表1##

例如:from user 这时候的##虚拟表1## 就是user表

2.join(链接表):

链接两张或多张表,生成##虚拟表2##

3.where语句:

①如果是单表查询,那么就没有join语句,此时where在##虚拟表1##操作,进行过滤,把满足where条件的数据过滤出来,生成##虚拟表3##
②如果多表查询,在这个##虚拟表2##中操作,进行过滤,把满足where条件的数据过滤出来,生成##虚拟表3##

4.group by语句:

对满足where条件的##虚拟表3##进行分组操作,分组完成后,生成##虚拟表4##

5.执行having过滤:

对##虚拟表4##进行过滤,但是一般都是用聚合函数,生成##虚拟表5##

6.select语句:

这个时候执行语句,select * 或 select id ,name ,password等,都是在##虚拟表5##中进行操作,把需要的字段从##虚拟表5##中提取出来,生成##虚拟表6##

7.order by语句:

根据##虚拟表6##中的某个字段进行排序,生成##虚拟表7##

8.limit字句:

在##虚拟表7##上操作,从指定位置取出数据,生成##最终表##

总结SQL执行顺序:

from>where>group by>having>select>order by>limit

做个笔记,这是原文链接: https://mp.weixin.qq.com/s/6f3hD5rLyiYukEGV00nBeg.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值