• ROW_NUMBER()函数的使用


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

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

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

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

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

     


     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语句其实等价于:


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

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


     1--Partition Page Demo
     2/* 取出第- 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一下就可以用了. 

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

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

    代码
     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

     

  • 相关阅读:
    jmeter 数据库类型的脚本
    jmeter 协议到脚本编写
    python socket粘包
    微信公众号开发
    常用windows和office激活工具
    分辨率等概念
    设置单元格同高或同宽
    单元格内容前或后增加内容
    单元格内数字复制和递增
    excel单元格内容换行
  • 原文地址:https://www.cnblogs.com/tangself/p/1838234.html
Copyright © 2020-2023  润新知