2

我正在尝试从我的数据库中选择代码,但在我有机会更新它们之前,我不需要另一个人来选择相同的代码。我曾尝试仅使用 updlock,这解决了我的重复销售问题,但它增加了死锁问题。所以现在我正在使用(UPDLOCK,READPAST),在我尝试在我的语句中使用 ORDER BY 之前,它工作得很好。

微软 SQL 2005

BEGIN TRANSACTION

SELECT Top 10 ID FROM dbo.CODES 
with (UPDLOCK, READPAST)
where ItemNo = 'type-2' AND Sold = 0 
order by cast(NowStamp as DateTime) ASC

COMMIT TRANSACTION

我觉得我的问题将来自索引。

4

1 回答 1

1

这是一个与ORDER BY 和 WITH(ROWLOCK, UPDLOCK, READPAST)非常相似的问题

答案描述您还需要 ROWLOCK 和索引。不幸的是,您无法在该列上创建索引,因为由于 CAST,它被认为是不确定的(请参阅http://msdn.microsoft.com/en-us/library/ms189292(v=sql. 90).aspx )。

您应该使用 CONVERT 并从以下位置指定确定性样式:http: //msdn.microsoft.com/en-us/library/ms187928 (v=sql.90).aspx

于 2013-07-24T22:05:38.407 回答