SQL 查询处理的步骤序号:
(1) FROM <left_table>
(2) <join_type> JOIN <right_table>
(3) ON <join_condition>
(4) WHERE <where_condition>
(5) GROUP BY <group_by_list>
(6) WITH {CUBE | ROLLUP}
(7) HAVING <having_condition>
(8) SELECT
(9) DISTINCT
(10) ORDER BY <order_by_list>
(11) <TOP_specification> <select_list>
以上每个步骤都会产生一个虚拟表,该虚拟表被用作下一个步骤的输入。这些虚拟表对调用者(客户端应 用程序或者外部查询)不可用。只有最后一步生成的表才会会给调用者。如果没有在查询中指定某一个子句, 将跳过相应的步骤。
首先,要清楚在一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##上操作,从指定位置取出数据,生成##最终表##
总结:from>where>group by>having>select>order by>limit