并发情况下 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) ;

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

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

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