mysql语句更新顺序_MySql语句执行顺序

Sql语句的执行顺序

例:SELECT `name`,COUNT(`name`) AS num FROM student WHERE grade < 60 GROUP BY `name` HAVING num >= 2 ORDER BY num DESC,`name` ASC LIMIT 0,2;

1、首先会执行from语句,把数据库的表文件加载到内存中。

2、执行where语句,根据筛选条件过滤出数据并且在内存中生成一张临时表。

3、如果有group by语句,会根据group by把内存中的临时表切割成多张临时表

4、执行select语句,如果语句中没有group by,则在临时表中执行select语句,若有group by语句,则会在多张临时表中分别执行select语句。

5、如果语句中有having关键字,则执行完select语句后执行having,对数据进行二次过滤,值得注意的是,执行where语句时,是不能用到字段别名的,因为执行where时,还没有执行select,所以这时是不能使用字段别名的,但是执行having时,是可以用字段别名的,因为having语句是在select语句执行之后执行的,所以可以用到字段别名。

6、当上述语句执行完成后,继续会执行order by语句,进行排序后执行limit分页语句,然后返回查询结果,结束当前sql语句的执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值