分布式程序对同一表进行操作时的sql

来源:互联网 发布:网络信号防雷器价格 编辑:程序博客网 时间:2024/05/23 21:30

分布式程序对同一表进行操作,为了不使多个进程同时打嘴仗一条sql语句,可用下面的sql

@"declare @id int

                                UPDATE NorthBoundQueue SET LastProcessTime = getdate(),@id=t1.NorthBoundQueueID 
                                FROM (SELECT TOP 1 * FROM NorthBoundQueue where DATEADD(millisecond, " + timeOut + @", LastProcessTime) < getdate() ORDER BY CreateTime ) AS t1
                                WHERE NorthBoundQueue.NorthBoundQueueID = t1.NorthBoundQueueID AND DATEADD(millisecond, 30000, NorthBoundQueue.LastProcessTime) < getdate()

                                SELECT TOP 1 * FROM NorthBoundQueue where NorthBoundQueue.NorthBoundQueueID = @id ";

原创粉丝点击