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

250 天前
 Ainokiseki
```UPDATE mytable set max_offset = ? where id='xxx' and max_offset < ?``` (传入?的两个值相同)

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

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

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

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

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

© 2021 V2EX