MySQL-高级篇(SQL执行顺序)

介绍

        mysql语句的书写顺序和执行顺序有很大差异。

1. 书写顺序

select

distinct <select_list>

from <left_table>

<join_type> join <right_table> on <join_condition>

where

<where_condition>

group by <group_by_column>

having <having_condition>

order by <oder_by_column>

limit <limit_number>

union <sql_script_2>

……

2. 执行顺序

  • from <left_table>  对from后面的表进行笛卡尔积(选择相对小的表做基础表)
  • on <join_condition> 筛选出满足on逻辑表达式的行
  • <join_type> join <right_table>
  • where <where_condition>  where条件在on之后执行,从左到右,从上到下
  • group by <group_by_column> 分组聚合(count、sum、avg等)
  • having <having_condition> 根据聚合函数进行再次过滤
  • select <select_list>  筛选需要查询的列数据
  • distinct  对数据进行去重
  • union 在order by之前执行
  • order by 排序 
  • limit 获取用户指定返回的数量

希望此篇文章能帮大家对mysql执行顺序有一个了解,感谢大家阅读

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值