我想使用ROW_NUMBER()来获得…

得到max(ROW_NUMBER())——>或者我猜这也将是所有行的计数

我试着这样做:

SELECT max(ROW_NUMBER() OVER(ORDER BY UserId)) FROM Users

但这似乎并不奏效……

要获得ROW_NUMBER()使用一个给定的信息,即。如果我有一个名字,我想知道它来自哪一行。

我认为这将类似于我在第1条中所尝试的内容

SELECT ROW_NUMBER() OVER(ORDER BY UserId) From Users WHERE UserName='Joe'

但这也不管用……

什么好主意吗?


当前回答

这个查询:

SELECT ROW_NUMBER() OVER(ORDER BY UserId) From Users WHERE UserName='Joe'

返回所有用户名是'Joe'的行,除非你没有用户名='Joe'

它们将按照UserID的顺序列出,row_number字段将以1开头并增加,但许多行包含UserName='Joe'

如果它对您不起作用,那么您的WHERE命令有问题,或者表中没有UserID。检查UserID和UserName字段的拼写。

其他回答

这个查询:

SELECT ROW_NUMBER() OVER(ORDER BY UserId) From Users WHERE UserName='Joe'

返回所有用户名是'Joe'的行,除非你没有用户名='Joe'

它们将按照UserID的顺序列出,row_number字段将以1开头并增加,但许多行包含UserName='Joe'

如果它对您不起作用,那么您的WHERE命令有问题,或者表中没有UserID。检查UserID和UserName字段的拼写。

可以使用Row_Number限制查询结果。

例子:

SELECT * FROM (
    select row_number() OVER (order by createtime desc) AS ROWINDEX,* 
    from TABLENAME ) TB
WHERE TB.ROWINDEX between 0 and 10

-- 通过上述查询,我将从TABLENAME中获得PAGE 1的结果。

SQL Row_Number()函数的作用是对相关记录集中的数据行进行排序并分配顺序号。因此,它被用于为行编号,例如,确定订单金额最高的前10行,或确定每个客户的订单金额最高,等等。

如果你想对数据集进行排序,并将每行划分为类别,我们使用Row_Number()和Partition by子句。例如,在数据集包含所有订单的情况下,对每个客户的订单进行排序等等。

SELECT
    SalesOrderNumber,
    CustomerId,
    SubTotal,
    ROW_NUMBER() OVER (PARTITION BY CustomerId ORDER BY SubTotal DESC) rn
FROM Sales.SalesOrderHeader

但据我所知,你想计算按列分组的行数。为了可视化需求,如果您希望在订单信息之外将相关客户的所有订单计数作为单独的列查看,可以使用count()聚合函数和Partition By子句

例如,

SELECT
    SalesOrderNumber,
    CustomerId,
    COUNT(*) OVER (PARTITION BY CustomerId) CustomerOrderCount
FROM Sales.SalesOrderHeader

如果你真的想使用ROW_NUMBER(而不是count(*)),你可以使用:

SELECT TOP 1 ROW_NUMBER() OVER (ORDER BY Id)   
FROM USERS  
ORDER BY ROW_NUMBER() OVER (ORDER BY Id) DESC
select 
  Ml.Hid,
  ml.blockid,
  row_number() over (partition by ml.blockid order by Ml.Hid desc) as rownumber,
  H.HNAME 
from MIT_LeadBechmarkHamletwise ML
join [MT.HAMLE] h on ML.Hid=h.HID