【发布时间】:2013-05-28 12:39:09
【问题描述】:
以下是我在一个表中更新管理器字段的查询。我面临的问题是我想在 RH 表中选择具有最新开始日期的用户 (NRH.AffectedUserNumber)。
WITH [NewReqHeader]
AS
(SELECT ROW_NUMBER()
OVER(ORDER BY RH.StartDate DESC) AS rowid
, RH.RequestId
, RH.RequestType
, RH.RequestStatusID
, RH.AffectedUserNumber
, RPD.TaskId
, RPD.HotelID
, RH.StartDate
FROM DBO.RequestPermissionDetail RPD
JOIN DBO.RequestHeader RH ON RH.RequestId = RPD.RequestId
AND RH.RequestType = 2
AND RH.RequestStatusID = 20
AND RPD.TaskId = 923
)
UPDATE #Facility_Manager
SET Manager = NRH.AffectedUserNumber
FROM #Facility_Manager FM
LEFT OUTER JOIN [NewReqHeader] NRH ON FM.FacilityId = NRH.HotelID
AND ISNULL(FM.FacilityId ,'') != ''
WHERE FM.SecPermissionCount > 1
【问题讨论】:
标签: sql sql-server sql-server-2008 join