有关于并发与锁的问题
+----+----------+---------+
| id | item | status |
+----+----------+---------+
| 1 | a | 1 |
+----+----------+---------+
| 2 | b | 0 |
+----+----------+---------+
| 3 | c | 0 |
+----+----------+---------+
| 4 | d | 0 |
+----+----------+---------+
| 5 | e | 0 |
+----+----------+---------+
| 6 | f | 0 |
+----+----------+---------+
| 7 | g | 0 |
+----+----------+---------+
有一个程序在轮巡这个表每次取出select top 1 * from tbl where status=0 的记录,然后将这条记录的status置为1,问题是如果是多线程的情况下,就可能出现一个线程已经把这条记录取出来了,在它把这条记录置为1之前又有另外的线程把这条记录取出来,出现取出多条一样的数据记录了。请问一下各位怎么解决这个问题?
------解决方案--------------------可以先把status更新为1:
update tbl set status = 1 from (select top 1 id from tbl where status=0) as t1 where tbl.id = t1.id
,然后使用触发器获得最近更新行的信息就可以了。这样可以避免出现楼主所说的问题吧!