我想使用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'
但这也不管用……
什么好主意吗?
需要使用WITH表AS创建虚拟表,这在给定的查询中提到。
通过使用这个虚拟表,您可以执行CRUD操作w.r.t row_number。
查询:
WITH table AS
-
(SELECT row_number() OVER(ORDER BY UserId) rn, * FROM Users)
-
SELECT * FROM table WHERE UserName='Joe'
-
你可以在最后一句中使用INSERT, UPDATE或DELETE,而不用SELECT。
虽然我同意其他人的观点,你可以使用count()来获得总的行数,下面是你如何使用row_count():
获取行总数no:
temp为(
选择row_number() over(按id排序)为rownum
从table_name
)
从temp中选择max(rownum)
获取名称为Matt的行号:
temp为(
选择name、row_number() over(按id排序)为rownum
从table_name
)
select rownum from temp where name like Matt
您可以进一步使用min(rownum)或max(rownum)分别获取Matt的第一行或最后一行。
这些都是row_number()的非常简单的实现。您可以将它用于更复杂的分组。检查我的高级分组不使用子查询的响应