表结构
id
name
pid
depth
数据
id | name | pid | depth |
---|---|---|---|
1 | A | 0 | 1 |
2 | B | 1 | 2 |
3 | C | 2 | 3 |
4 | D | 2 | 3 |
5 | E | 0 | 1 |
6 | F | 4 | 2 |
省略 |
问题:需要将 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) ;
这样处理下级比较少的话没什么问题。如果下级很多有几百上千个,那岂不是要锁很多了;
还请各位给个思路或者方案,感谢。