Nếu ý của bạn là khóa loại hàng đợi an toàn đồng thời, thì hãy sử dụng gợi ý ROWLOCK, UPDLOCK, READPAST?
Điều kiện chạy hàng đợi quy trình SQL Server
BEGIN TRAN
SELECT TOP 1 @QueryID = [ID] from Table WITH (ROWLOCK, UPDLOCK, READPAST)
UPDATE Table SET [Read] = 1 WHERE [ID] = @QueryID
COMMIT TRAN -- TRAM
Tuy nhiên, trong một tuyên bố. một cái gì đó giống như
WITH T AS
(
--ORDER BY with TOP , or perhaps MIN is better?
SELECT TOP 1 [Read], [ID] from Table
WITH (ROWLOCK, UPDLOCK, READPAST) ORDER BY [Read]
)
UPDATE
T
SET
[Read] = 1;