只喜欢吃芒果 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日

悬赏问题

  • ¥20 怎么在stm32门禁成品上增加记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀
  • ¥15 flink cdc无法实时同步mysql数据
  • ¥100 有人会搭建GPT-J-6B框架吗?有偿
  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 解riccati方程组