我想使用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 COUNT(*) FROM myTable
为了得到计数。
对于第二个问题,行的主键是用来标识特定行的。不要尝试使用行号。
如果在主查询中返回Row_Number(),
SELECT ROW_NUMBER() OVER (Order by Id) AS RowNumber, Field1, Field2, Field3
FROM User
然后,当您想返回5行时,您可以获取当前行号并使用以下查询来确定currentrow为-5的行
SELECT us.Id
FROM (SELECT ROW_NUMBER() OVER (ORDER BY id) AS Row, Id
FROM User ) us
WHERE Row = CurrentRow - 5
需要使用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。