之乎者也,阿弥陀佛

软件设计的原则就是,化繁为简,化难为易,把人的思维集中在简单的领域,然后通过有序的组合实现复杂的逻辑。

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
在CSDN看到看到一条SQL查询语句的问题,如下所示:

select *,row_number() over(order by productname) as rownumber
from products where rownumber between 10 and 20 

 

问题是这条SQL语句会报错。经过分析发现,这跟SQL的解析顺序有关系因为在计算where的时候row_number还没算出来。所以SQL语句会报错。

标准SQL解析顺序如下所示:

   (1).FROM 子句, 组装来自不同数据源的数据
   (
2).WHERE 子句, 基于指定的条件对记录进行筛选
   (
3).GROUP BY 子句, 将数据划分为多个分组
   (
4).使用聚合函数进行计算
   (
5).使用 HAVING 子句筛选分组
   (
6).计算所有的表达式
   (
7).使用 ORDER BY 对结果集进行排序

 

posted on 2010-09-30 10:27  搏击的小船  阅读(461)  评论(0编辑  收藏  举报