ROW_NUMBER()函数的使用

Row_number() over只是用于把查询的数据,为他增加一列连续的ID数

ROW_NUMBER()函数是Sql 2005中新添的一个函数。通常它被用在分页的SQL语句中。

微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。

我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。

   上边可能说的不是很清楚,请结合下边这个例子来看吧!

 

ContractedBlock.gif ExpandedBlockStart.gif Code
 1USE Northwind
 2GO
 3
 4--
 5SELECT OrderID, 
 6    CustomerID, 
 7    OrderDate
 8FROM dbo.Orders WITH(NOLOCK)
 9
10SELECT OrderID, 
11    CustomerID, 
12    OrderDate, 
13    ROW_NUMBER() OVER(ORDER BY orderID DESCAS 字段编号
14FROM dbo.Orders WITH(NOLOCK)

第一个查询只是一个普通的查询,查询出Orders表中的3个字段的记录。其结果为:

 

第二个查询相比第一个查询仅仅是多了“ ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号 这段语句。我们来分析一下这段语句。

这段语句的作用就是利用ROW_NUMBER()函数根据OrderID这列来生成一个新的数据列,这列的名称为字段编号。然后我们根据ORDER BY orderID DESC来指定字段编号这列按照OrderID的逆序来生成,结果如下:

 

比较两个结果集,会发现第二个结果集是按照OrderID字段逆序的记录,其实也可看成是字段编号这个字段的正序排序,ROW_NUMBER()函数相当于为SELECT语句末尾加了ORDER BY子句,第二个SELECT语句其实等价于:

 

ContractedBlock.gif ExpandedBlockStart.gif Code
1SELECT OrderID, 
2    CustomerID, 
3    OrderDate, 
4    ROW_NUMBER() OVER(ORDER BY OrderID DESCAS 字段编号
5FROM dbo.Orders WITH(NOLOCK)
6ORDER BY 字段编号ASC

 

下边来看一个对ROW_NUMBER()函数的简单分页应用。

 

ContractedBlock.gif ExpandedBlockStart.gif Code
 1--Partition Page Demo
 2ExpandedBlockStart.gifContractedBlock.gif/**//* 取出第- 200条的记录(记录须按OrderID排序)*/
 3
 4WITH OrdersByOrderIDASC AS 
 5(
 6    SELECT OrderID, 
 7        CustomerID, 
 8        OrderDate, 
 9        ROW_NUMBER() OVER(ORDER BY orderID ASCAS 字段编号
10    FROM dbo.Orders WITH(NOLOCK)
11)
12
13SELECT * 
14FROM OrdersByOrderIDASC WITH(NOLOCK)
15WHERE 字段编号BETWEEN 100 AND 110

 

首先把应用ROW_NUMBER()函数后的结果集存在一张临时表中,然后以字段编号这个字段为条件,使用BETWEEN关键字过滤相应的记录。

 

以上就是我对ROW_NUMBER()函数的一点粗浅认识,希望可以帮到大家!

 

巧用 ROW_NUMBER() 生成不重复的唯一排序码,按客户的需要任意排序数据

最近项目里遇到这样的一个小技术问题,新闻可以任意按客户的需要进行排序,需要实现的效果图如下:

由于各种类别输入了蛮多测试信息,有几百条数据,一个个把排序码都生成也很麻烦,看能否没有什么好办法能生成不重复的,唯一排序码?达到如下效果?

总不可能人工的一个个输入吧? 也没那个耐心的,还是想想有什么好办法吧?

 

其实很快就想到了 ROW_NUMBER() 功能,用这个,应该是可行的,折腾了一小会儿,这个SQL语句就写好了,给大家分享一下,有需要的朋友们可以直接拿过来就可以用了,虽然也没什么难的,但是自己写总会折腾一会儿,直接复制过去修改一下,省心省事一些。

 

1  UPDATE BASE_NEWS
2     SET SortCode  =  NEWS.SortCode
3   FROM (SELECT ROW_NUMBER() OVER (ORDER BY CreateDate DESC)  +   10000000  AS SortCode
4                , Id
5           FROM BASE_NEWS) AS NEWS
6  WHERE NEWS.Id  =  BASE_NEWS.Id

 

此文虽然是过于基础了一些,但是往往基础的东西,大家日常生活里需要得更多,希望能对需要的人起点儿参考作用,可以COPY一下就可以用了. 

若有谁可以写得更好,也可以贴出来分享一下。

 

四个按钮中的代码实现可以参考一下

 

ExpandedBlockStart.gif 代码
 1           #region  private void SetSort(string function, int index) 设置排序顺序
 2           ///   <summary>
 3           ///  设置排序顺序
 4           ///   </summary>
 5           ///   <param name="function"> 排序动作 </param>
 6           ///   <param name="index"> 索引 </param>
 7           private   void  SetSort( string  function,  int  index)
 8          {
 9               string  id  =   this .gridView.DataKeys[index].Value.ToString();
10               string  targetId  =   string .Empty;
11               try
12              {
13                   this .DbHelper.Open();
14                   //  判断编辑权限
15                   //  this.CheckPermission(this.CategoryId, OperationCode.Edit);
16                   switch  (function)
17                  {
18                       case  BaseDbSortLogic.CommandSetTop:
19                           if  (index  >   0 )
20                          {
21                              BaseDbSortLogic.SetTop( this .DbHelper, ProjectTable.TableName, id);
22                               this .gridView.SelectedIndex  =   0 ;
23                          }
24                           break ;
25                       case  BaseDbSortLogic.CommandSetUp:
26                           if  (index  >   0 )
27                          {
28                              targetId  =   this .gridView.DataKeys[index  -   1 ].Value.ToString();
29                               this .gridView.SelectedIndex  =  index  -   1 ;
30                              BaseDbSortLogic.Swap( this .DbHelper, ProjectTable.TableName, id, targetId);
31                          }
32                           break ;
33                       case  BaseDbSortLogic.CommandSetDown:
34                           if  ((index  +   2 <   this .gridView.Rows.Count)
35                          {
36                              targetId  =   this .gridView.DataKeys[index  +   1 ].Value.ToString();
37                               this .gridView.SelectedIndex  =  index  +   1 ;
38                              BaseDbSortLogic.Swap( this .DbHelper, ProjectTable.TableName, id, targetId);
39                          }
40                           break ;
41                       case  BaseDbSortLogic.CommandSetBottom:
42                           if  ((index  +   2 <   this .gridView.Rows.Count)
43                          {
44                              BaseDbSortLogic.SetBottom( this .DbHelper, ProjectTable.TableName, id);
45                               this .gridView.SelectedIndex  =   this .gridView.Rows.Count  -   2 ;
46                          }
47                           break ;
48                  }
49                   //  获取列表
50                   this .DoSearch();
51              }
52               catch  (Exception ex)
53              {
54                   this .LogException(ex);
55                   throw  ex;
56              }
57               finally
58              {
59                   this .DbHelper.Close();
60              }
61          }
62           #endregion

 

 

 

转载于:https://www.cnblogs.com/tangself/archive/2010/09/29/1838234.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值