您的位置:首页 > 数据库

SQL语句中,为什么where子句不能使用列别名,而order by却可以?

2015-08-28 10:42 721 查看
sqlserver(其他数据库类似)查询的执行顺序是:
(1)FROM <left_table> <join_type> JOIN <right_table> ON <on_predicate>  
(2)WHERE <where_predicate>
(3)GROUP BY <group_by_specification>    查询  别名开始存在    此处开始才可以使用别名
(4)H***ING <having_predicate>
(5)SELECT DISTINCT TOP(<top_specification>) <select_list>    
(6)ORDER BY <order_by_list>                

所以在where执行的时候,别名还不存在,而order by的时候已经存在
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: