ROW_NUMBER()函数的使用
2015-07-27 13:55
253 查看
Row_number() over只是用于把查询的数据,为他增加一列连续的ID数
ROW_NUMBER()函数是Sql 2005中新添的一个函数。通常它被用在分页的SQL语句中。
微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。
上边可能说的不是很清楚,请结合下边这个例子来看吧!
1
USE Northwind
2
GO
3
4
--
5
SELECT OrderID,
6
CustomerID,
7
OrderDate
8
FROM dbo.Orders WITH(NOLOCK)
9
10
SELECT OrderID,
11
CustomerID,
12
OrderDate,
13
ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号
14
FROM 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语句其实等价于:
1
SELECT OrderID,
2
CustomerID,
3
OrderDate,
4
ROW_NUMBER() OVER(ORDER BY OrderID DESC) AS 字段编号
5
FROM dbo.Orders WITH(NOLOCK)
6
ORDER BY 字段编号ASC
下边来看一个对ROW_NUMBER()函数的简单分页应用。
1
--Partition Page Demo
2
/* 取出第- 200条的记录(记录须按OrderID排序)*/
3
4
WITH OrdersByOrderIDASC AS
5
(
6
SELECT OrderID,
7
CustomerID,
8
OrderDate,
9
ROW_NUMBER() OVER(ORDER BY orderID ASC) AS 字段编号
10
FROM dbo.Orders WITH(NOLOCK)
11
)
12
13
SELECT *
14
FROM OrdersByOrderIDASC WITH(NOLOCK)
15
WHERE 字段编号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
转载自http://www.cnblogs.com/tangself/archive/2010/09/29/1838234.html
ROW_NUMBER()函数是Sql 2005中新添的一个函数。通常它被用在分页的SQL语句中。
微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。
上边可能说的不是很清楚,请结合下边这个例子来看吧!
1
USE Northwind
2
GO
3
4
--
5
SELECT OrderID,
6
CustomerID,
7
OrderDate
8
FROM dbo.Orders WITH(NOLOCK)
9
10
SELECT OrderID,
11
CustomerID,
12
OrderDate,
13
ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号
14
FROM 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语句其实等价于:
1
SELECT OrderID,
2
CustomerID,
3
OrderDate,
4
ROW_NUMBER() OVER(ORDER BY OrderID DESC) AS 字段编号
5
FROM dbo.Orders WITH(NOLOCK)
6
ORDER BY 字段编号ASC
下边来看一个对ROW_NUMBER()函数的简单分页应用。
1
--Partition Page Demo
2
/* 取出第- 200条的记录(记录须按OrderID排序)*/
3
4
WITH OrdersByOrderIDASC AS
5
(
6
SELECT OrderID,
7
CustomerID,
8
OrderDate,
9
ROW_NUMBER() OVER(ORDER BY orderID ASC) AS 字段编号
10
FROM dbo.Orders WITH(NOLOCK)
11
)
12
13
SELECT *
14
FROM OrdersByOrderIDASC WITH(NOLOCK)
15
WHERE 字段编号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
转载自http://www.cnblogs.com/tangself/archive/2010/09/29/1838234.html
相关文章推荐
- VBA与宏
- Android 超高仿微信图片选择器 图片该这么加载
- libvirt cpu model
- uboot从nand启动
- Java初学项目------满汉楼:工具栏+菜单栏
- 30天自制操作系统day22
- 工作经验应该这么写,有模板哦!
- 基于Monkey的Android自动化测试
- c++ bitset与位压缩
- LeetCode 237 : Delete Node in a Linked List
- 201507271337_《Backbone之三——Event、Controller(Router)、View、Collection、Model》
- ExtJs和JQuery应用的比较
- 一个让你学习SQL语句的教程
- ubuntu安装jdk之后,报错java/lang/NoClassDefFoundError: java/lang/Object的解决办法
- Android 防止快速 点击 多次
- 利用shell脚本批量复制文件到给定目录
- mybatis中关于传入参数parameterType
- django 1.8 官方文档翻译: 3-4-2 内建显示视图
- HDU 5296 Annoying problem
- AT&T计划削减支出 SDN头功