首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

有关于并发与锁的有关问题

2012-02-06 
有关于并发与锁的问题+----+----------+---------+|id|item|status|+----+----------+---------+|1|a|1|+-

有关于并发与锁的问题


+----+----------+---------+
|   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
,然后使用触发器获得最近更新行的信息就可以了。这样可以避免出现楼主所说的问题吧!

热点排行