只喜欢吃芒果 2021-09-24 15:40 采纳率: 100%
浏览 20
已结题

并发情况下 mysql 树型的表结构 如何更新 depth 字段?

表结构

id
name 
pid
depth

数据

idnamepiddepth
1A01
2B12
3C23
4D23
5E01
6F42
省略

问题:需要将 B 移动至 F 下面,并改变 depth 字段

不考虑并发很容就解决了

并发情况下

如果采用加锁方式解决
那么就需要将 B 这条数据锁住,同时需要将F锁住(新上级)且 B 的所有下级也要锁住(C、D)。
然后 更新 B的数据,然后拿新旧数据中的depth字段进行 新 depth - 旧 depth 得到结果 tDepth
然后去更新下级的 depth

update xxx set depth = depth + tDepth where id in(3,4) ;

这样处理下级比较少的话没什么问题。如果下级很多有几百上千个,那岂不是要锁很多了;

还请各位给个思路或者方案,感谢。

  • 写回答

1条回答 默认 最新

  • 於黾 2021-09-24 15:53
    关注

    加锁是锁表,不是锁一条数据啊
    直接锁住整个表,一个线程处理完才允许别的线程处理

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月4日
  • 已采纳回答 9月26日
  • 创建了问题 9月24日