我使用以下查询(在SQL Server 2008中)从表中获取最后20条记录。
查询按预期工作,我唯一的问题是这是一个日志表,其中某个itemID
可以多次出现。有没有办法我只能在这里选择唯一的itemID?
我尝试使用DISTINCT,但这不起作用,因为不是整行都是重复的,只是itemID可以出现多次(然后时间戳或其他数据不同)。
我的SQL:
ALTER PROCEDURE [dbo].[RC_FetchUpdates]
@departmentID int
AS
BEGIN
SET NOCOUNT ON;
SELECT TOP 20 A.itemID,
A.lastUpdate,
CONVERT(VARCHAR(11), A.modTime, 106) AS modTime,
A.modBy,
B.itemName,
B.linkRef
FROM RC_LogLinks A
LEFT JOIN RC_Links B
ON B.itemID = A.itemID
WHERE B.departmentID = @departmentID
AND A.lastUpdate <> 'Deleted'
ORDER BY A.modTime desc, B.itemName
FOR XML PATH('updates'), ELEMENTS, TYPE, ROOT('ranks')
END
答案 0 :(得分:2)
会是这样的:
WITH rankedLogLinks AS (
SELECT ROW_NUMBER() OVER (PARTITION BY A.itemID ORDER BY A.modTime DESC) AS rownum, A.itemID, A.lastUpdate, A.modTime, A.modBy
FROM RC_LogLinks A
WHERE A.lastUpdate <> 'Deleted'
)
SELECT r.itemID, r.lastUpdate, CONVERT(VARCHAR(11), r.modTime, 106) AS modTime, r.modBy, B.itemName, B.linkRef
FROM rankedLogLinks r
LEFT JOIN RC_Links B
ON B.itemID = r.itemID
WHERE B.departmentID = @departmentID
AND r.rownum = 1
ORDER BY B.itemName
FOR XML PATH('updates'), ELEMENTS, TYPE, ROOT('ranks')
;
您可能想要更改WHERE A.lastUpdate&lt;&gt;的位置根据您的要求,从第一个查询“删除”到第二个查询。