当 select 和 其他三种语句的一者或者多者同时出现时,他们之间是存在执行先后顺序的。
他们的优先级顺序是:where > group by > select > order by > limit
目录
1、select 与 where
2、group by 与 where 、select
2、select 与 order by
3、order by 与 limit
4、优先级证明
1、select 与 where
select是展示查询结果,where是条件筛选。这里存在两种情况:
- select先,where后:先查询到所有的记录,然后再按条件筛选出符合条件的,
- where先,select后:筛掉不符合条件的,然后再展示符合条件的
很显然,后者是效率比较高的,站在C语言的逻辑就是,for循环遍历所有的记录,每遍历一条记录就判断该记录是否符合条件,不符合就舍弃;符合条件就加入到数组。
因此,where > select
2、group by 与 where 、select
where 是整表记录的筛选,group by是根据某一个字段的内容进行分组。
先进行整表筛选可以减少要分组的记录,然后group by 在筛选完的基础上进行分组,最后select在每一个分组中做查询操作。
因此,where > group by > select
2、select 与 order by
select是展示查询结果,order by 是排序,这里同样也分为两种情况:
- select先,order by后:先查询到所有的记录,然后排序
- order by先,select后:每遍历到一条记录,就对其进行排序,这样很显然,效率不高,说不定要重复遍历之前的记录
因此,前者的效率高一点,即 select > order by
3、order by 与 limit
order by 是排序,limit是截取,这里已经无需比较了,很显然是先排序,然后再截取,因为先选出几行,然后再排序没有意义。
因此,order by > limit
4、优先级证明
从上述介绍可以得出优先级顺序:where > select > order by > limit
我们可以在select语句中,为某个字段起一个别名,按照上述优先级,where子句中是无法使用该别名的,但是 order by 和 limit 子句可以使用该别名。
where中无法使用 select 定义的别名
但是order by中可以使用select定义的别名