VerySource

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 983|回复: 5

有关于并发与锁的问题

[复制链接]

1

主题

2

帖子

3.00

积分

新手上路

Rank: 1

积分
3.00
发表于 2020-3-3 12:30:01 | 显示全部楼层 |阅读模式


+----+----------+---------+
| 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之前又有另外的线程把这条记录取出来,出现取出多条一样的数据记录了。请问一下各位怎么解决这个问题?
回复

使用道具 举报

0

主题

114

帖子

69.00

积分

新手上路

Rank: 1

积分
69.00
发表于 2020-5-15 06:45:01 | 显示全部楼层
取的时候加条件取非0的?
回复

使用道具 举报

1

主题

2

帖子

3.00

积分

新手上路

Rank: 1

积分
3.00
 楼主| 发表于 2020-5-16 17:00:01 | 显示全部楼层
先取为0的然后再将取出的记录更新为1
回复

使用道具 举报

0

主题

6

帖子

5.00

积分

新手上路

Rank: 1

积分
5.00
发表于 2020-7-31 15:30:01 | 显示全部楼层
可以先把status更新为1:
update tbl set status = 1 from (select top 1 id from tbl where status=0) as t1 where tbl.id = t1.id
,然后使用触发器获得最近更新行的信息就可以了。这样可以避免出现楼主所说的问题吧!
回复

使用道具 举报

0

主题

6

帖子

5.00

积分

新手上路

Rank: 1

积分
5.00
发表于 2020-7-31 15:45:01 | 显示全部楼层
触发器里面的语句这样写
if update(status)
begin
     select * from deleted,inserted where deleted.status = 0 and inserted.status = 1
end
回复

使用道具 举报

0

主题

6

帖子

5.00

积分

新手上路

Rank: 1

积分
5.00
发表于 2020-7-31 16:30:01 | 显示全部楼层
上边写的返回列太多了,应该这样:
if update(status)
begin
     select deleted.id,deleted.item,deleted.status from deleted,inserted where deleted.status = 0 and inserted.status = 1
end
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|CopyRight © 2008-2023|verysource.com ( 京ICP备17048824号-1 )

快速回复 返回顶部 返回列表