简述sql server逻辑查询处理的各个阶段
来源:互联网 作者:未知 日期:2010年01月07日 访问次数:
本文介绍逻辑查询处理所涉及的各个阶段,对各个阶段的含义和顺序给读者作为参考,以下代码列出查询的一般形式、并根据各个字句被逻辑处理的顺序附以步骤序号。
Sql不同于其他编程语言的显著特征在于处理代码的顺序,大多数编程语言中,代码按编码顺序被处理,而sql语言中,每个被第一处理的子句是FROM子句,尽管SELECT语句第一个出现,但几乎总是最后被处理。
每步会产生一个虚拟表,该虚拟表会被用作下一个步骤的输入,虚拟表对调用者是不可用的只有最后一步生成的表才会返回给调用者,如果没有在查询中指定某一子句,将会跳过相应步骤,下面是对sql server各个逻辑步骤的阐述。
1、FROM:对FROM子句中的前两个表执行笛卡尔积(交叉连接)生成虚拟表VT1;
2、ON:对VT1应用ON筛选器,只有使〈join_condition〉为真的行才被插入VT2;
3、OUTER(JOIN):如果指定了OUTER(JOIN)保留表中未找到匹配的行将作为外部行添加到VT2生成VT3,如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1和3,知道处理完所有表为止;
4、WHERE:对VT3应用WHERE筛选器,只有〈where_condition〉为TRUE的行才被插入VT4;
5、GROUP BY:按GROUP BY子句中的列列表对VT4中的行分组,生成VT5
6、Cube|rollup:把超组(supergroups)插入VT5,生成VT6;
7、HAVING:对VT6应用HAVING筛选器,只有使(having_condition)为TRUE的组才会被插入VT7
8、SELECT:处理SELECT列表产生VT8
9、Distinct:将重复的行从VT8中移除产生VT9
10、ORDER BY:将VT9中的行按ORDER BY子句中的列列表顺序排序,生成一个游标VC10
11、TOP:从VC10的开始处选择指定数量活比例的行,生成表VT11返回给调用者。
Sql不同于其他编程语言的显著特征在于处理代码的顺序,大多数编程语言中,代码按编码顺序被处理,而sql语言中,每个被第一处理的子句是FROM子句,尽管SELECT语句第一个出现,但几乎总是最后被处理。
每步会产生一个虚拟表,该虚拟表会被用作下一个步骤的输入,虚拟表对调用者是不可用的只有最后一步生成的表才会返回给调用者,如果没有在查询中指定某一子句,将会跳过相应步骤,下面是对sql server各个逻辑步骤的阐述。
1、FROM:对FROM子句中的前两个表执行笛卡尔积(交叉连接)生成虚拟表VT1;
2、ON:对VT1应用ON筛选器,只有使〈join_condition〉为真的行才被插入VT2;
3、OUTER(JOIN):如果指定了OUTER(JOIN)保留表中未找到匹配的行将作为外部行添加到VT2生成VT3,如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1和3,知道处理完所有表为止;
4、WHERE:对VT3应用WHERE筛选器,只有〈where_condition〉为TRUE的行才被插入VT4;
5、GROUP BY:按GROUP BY子句中的列列表对VT4中的行分组,生成VT5
6、Cube|rollup:把超组(supergroups)插入VT5,生成VT6;
7、HAVING:对VT6应用HAVING筛选器,只有使(having_condition)为TRUE的组才会被插入VT7
8、SELECT:处理SELECT列表产生VT8
9、Distinct:将重复的行从VT8中移除产生VT9
10、ORDER BY:将VT9中的行按ORDER BY子句中的列列表顺序排序,生成一个游标VC10
11、TOP:从VC10的开始处选择指定数量活比例的行,生成表VT11返回给调用者。
上一篇:COUNT 返回组中项目的数量
下一篇:没有了
发表评论
