教你学会Sql中 ROW_NUMBER的用法

ROW_NUMBER SqlServer 2005 推出的新功能。
语法:select *,ROW_Number() over(order by 字段) as '新列名' from table
顾名思义:ROW_NUMBER() 为根绝条件查询出来的数据添加一列(有序的一列,连续序号的1,2,3....),虽然说数据库中的表的自增列的ID也是连续的,
但是根据筛选条件或者删除行导致ID序号出现断号,而ROW_NUMBER()这个方法恰恰可以生成一个新的一列(序号相连),最主要的应用就是SQL分页;
1select * from Table_1

 

图一  

(2)select ROW_NUMBER() over(order by name desc) as zhong, * from Table_1

图二   按照一个字段,生成一个新的具有排序功能的字段,本例是生成了一个有序号zhong字段,按照name的倒序排。

(3)select ROW_NUMBER() over(order by name desc) as zhong, * from Table_1 order by zhong desc

图三  代码的最终排序结果是按照sql中的order by 而不是按照ROW_NUMBER()中 over的order by 排序的。

(4)使用ROW_NUMBER()函数可以查找指定范围内的数据,实现分页功能。

string sql = String.Format("select * from (select *,ROW_NUMBER() over(order by id) as row from Table_1 where name='{0}') t where row>={1} and row<{2} ",
                        Name.ToString(),
                       ((pageIndex - 1) * pageSize).ToString(),
                       ((pageIndex) * pageSize).ToString()
                   );

把查询出来的结果又按照序号排了一次序,然后根据索引和每页的个数,就能够查出每一次同步请求的分页的数。

(5)不使用ROWER_NUMBER()也能够实现查询指定范围的内容,使用Top来限定范围(3个select)

string sql = "select id from (select top(2)id from (select top(5) id from Table_1 order by id asc) t order by id  desc) m order by id asc"

 注意:sql语句子查询中的 order by 排序,子句和主句都要写,若子句中不写,主句中的排序会影响到子句。

posted @ 2012-07-31 17:26  学之乐  阅读(1344)  评论(0编辑  收藏  举报