求问关于并发更新数据库的潜在数据冲突

2024-04-17 22:04:04 +08:00
 Ainokiseki
```UPDATE mytable set max_offset = ? where id='xxx' and max_offset < ?``` (传入?的两个值相同)

上面这条 sql 语句,如果 n 个线程并发执行,对应的值分别为 1 ,2 ,……,n ,是否有可能最终得到的 max\_offset 不是最大值 n?是否需要加锁来保证并发安全?数据库隔离级别为 read\_commited
1776 次点击
所在节点    MySQL
5 条回复
sagaxu
2024-04-17 22:16:35 +08:00
update 或者 select for update 自己会锁,不用额外加锁
kanepan19
2024-04-18 09:05:39 +08:00
你的语句本身就是线程安全的, 执行的有的会成功,有的会失败, 判断好,执行结果就行
LiaoMatt
2024-04-18 09:07:25 +08:00
不论隔离级别是啥都不允许脏写, update 是当前读, 你的条件会加间隙锁,其他的事务会阻塞,直到事务提交,或者超时
siweipancc
2024-04-18 12:16:15 +08:00
最终一致性只要执行 n++就行,只要接受每次更新返回的结果跟预期不一致,或者改成乐观更新,这样子就是可预期的
andykuen959595
2024-04-18 17:19:43 +08:00
试试先查询 插入临时表 最后根据主键进行修改

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1033409

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX