mysql - sql的执行顺序

sql中用到的关键字及执行顺序:

  1. from
  2. on  join (先on后where,on是在建立关联关系生成临时表时执行,where是在临时表生成后对数据进行筛选的)
  3. where
  4. group by(从这一步开始,可以使用select中的别名。所以where中不可以使用select中的别名,而having却可以)
  5. avg,sum...
  6. having
  7. select
  8. distinct
  9. order by
  10. limit

从from开始,每执行一步,都会生成对应的虚拟表,这个虚拟表作为下一步的输入,然后再生成新的虚拟表。。。

 

 

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##上操作,从指定位置取出数据,生成##最终表##

 

 

 

总结:from>where>group by>having>select>order by>limit

 

posted @ 2022-07-22 11:45  小虫虫大虫虫  阅读(180)  评论(0编辑  收藏  举报