sql server之ROW_NUMBER() OVER()取每组的第N行数据

先看个例子:

document_id card_holder_id created_date document_type_id
1 1 2015-7-1 1
2 4 2015-7-2 1
3 4 2015-7-3 5

table: document

大致的场景就是

取每个card holder的最新的一条document_type_id为5数据, 并取得document_type_name的值(需要join另外一张表, 这里就不列出来了)。

SQL实现:

SELECT
    document_type_id
FROM
(
    -- 按card holder分组 按created_date降序排列
    SELECT
        ROW_NUMBER()
        OVER (
            PARTITION BY card_holder_id
            ORDER BY created_date DESC
        ) AS row,
        document_type_id
    FROM
        document
    WHERE document_type_id = 5
)AS T
WHERE T.row = 1
-- 这里取的是第一行数据

定义

返回结果集分区内行的序列号,每个分区的第一行从 1 开始。

语法

ROW_NUMBER() OVER( [ PARTITION BY [COLUMN1] ] ORDER BY [COLUMN2])

绿色字体表示选填, 即: ROW_NUMBER() OVER(ORDER BY [COLUMN])。

备注   

除非以下条件成立,否则不保证在每次执行时,使用 ROW_NUMBER() 的查询所返回行的顺序完全相同。

  1. 分区列的值是唯一的。
  2. ORDER BY 列的值是唯一的。
  3. 分区列和 ORDER BY 列的值的组合是唯一的。
时间: 2024-10-26 23:21:34

sql server之ROW_NUMBER() OVER()取每组的第N行数据的相关文章

SQL Server数据库ROW_NUMBER()函数使用

下面以几个实例来说明ROW_NUMBER()函数的使用. 实例如下: 1.使用row_number()函数进行编号,如 select email,customerID, ROW_NUMBER() over(order by psd) as rows from QT_Customer 原理:先按psd进行排序,排序完后,给每条数据进行编号. 2.在订单中按价格的升序进行排序,并给每条记录进行排序代码如下: select DID,customerID,totalPrice,ROW_NUMBER() 

SQL Server数据库ROW_NUMBER()函数使用详解

SQL Server数据库ROW_NUMBER()函数使用详解 摘自:http://database.51cto.com/art/201108/283399.htm SQL Server数据库ROW_NUMBER()函数的使用是本文我们要介绍的内容,接下来我们就通过几个实例来一一介绍ROW_NUMBER()函数的使用. 实例如下: 1.使用row_number()函数进行编号,如 select email,customerID, ROW_NUMBER() over(order by psd) a

sql server 获取每一个类别中值最大的一条数据

sql server 获取每一个类别中值最大的一条数据 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 /* 数据如下: name val memo a    2   a2(a的第二个值) a    1   a1--a的第一个值 a    3   a3:a的第三个值 b    1   b1--b的第一个

【SQL SERVER】 搭建AlwaysON高可用组

项目需要保障数据的高可用,于是可选的方案无非是Oracle集群. 传统的主从+心跳切换访问点以及SQL Server AlwaysOn这类方案.(//经验不多,了解和实践过的方案就这类,轻拍) Oracle太大,项目初期的核心开发人员并不会用(从高校中途接手的项目,前期都是研究生在做),所以本身就被限制在SQL Server这个技术栈里了,好在了解到SQL Server 2012开始具备AlwaysOn的组件,完全满足项目要求,所以这个方案就这么确定了. [SQL AlwaysOn技术简介] A

如何还原SQL Server 数据库到Always On可用性组

问题描述 ============== 如何还原SQL Server 数据库到AlwaysOn可用性组 问题解答 ==============我们无法在一个可用组的数据库上执行还原操作,如果需要的话,我们必须从可用性组中删除数据库然后再还原和重新配置.它与您在镜像或日志传送方案中所使用的类似. 下面是相关的步骤去还原SQL Server数据库到AlwaysOn可用性组 步骤1: 从可用性组中删除数据库 1)在新的主服务器上,扩展可用性组的可用性数据库的列表. 2)右键单击要还原的数据库,然后选择

sql server 里的文件和文件组使用

转自:https://www.cnblogs.com/woodytu/p/5821827.html 在今天的文章里,我想谈下SQL Server里非常重要的话题:SQL Server如何处理文件的文件组.当你用CREATE DATABASE命令创建一个简单的数据库时,SQL Server为你创建2个文件: 一个数据文件(.mdf) 一个事务日志文件(.ldf) 数据文件本身在有且只有一个主文件组里创建.默认情况下,在主文件组里,SQL Server存储素有的数据(用户表,系统表等).那有额外的文

Sql server的Merge语句,源表中如果有重复数据会导致执行报错

用过sql server的Merge语句的开发人员都应该很清楚Merge用来做表数据的插入/更新是非常方便的,但是其中有一个问题值得关注,那就是Merge语句中的源表中不能出现重复的数据,我们举例来说明这个问题. 现在我们有一张表叫T_Class_A,其建表语句如下: CREATE TABLE [dbo].[T_Class_A]( [ID] [int] IDENTITY(1,1) NOT NULL, [ClassName] [nvarchar](50) NULL, [StudentTotalCo

【MySQL】【13】分组查询取每组最新的一条数据

前言:获取所有用户填写的最新一条地址数据 正文: 错误写法: mysql5.7时,子查询的排序已经变为无效了 SELECT * FROM (SELECT * FROM address ORDER BY create_time DESC) a GROUP BY user_id 方法1: 此时子查询就不光是排序,所以此时排序会生效,但有条数限制 SELECT * FROM (SELECT * FROM address ORDER BY create_time DESC LIMIT 10000) a

SQL学习(三)Select语句:返回前多少行数据

在实际工作中,我们可能根据某种排序后,只需要显示前多少条数据,此时就需要根据不同的数据库,使用不同的关键字 一.SQL Server/Access select top 数量/百分比 from table 如: select top 10 from ticket---返回ticket表中的前10行数据 select top 10 from ticket where name='测试'---返回ticket表中,name为测试的前10行数据 select top 10 from ticket or