树型结构数据存储-左右值编码法

树型结构数据存储-左右值编码法

说明

在这里插入图片描述

  • lft:左值
  • rgt:右值
  • lv:层级深度
  • 优点:平行查询,无限分类,查询效率高
  • 缺点:增删改,涉及到多节点调整,效率低

新增

在这里插入图片描述

  1. 取出上级的左值、右值、深度,命名为lft_p、rgt_p、lv_p

    • 上级存在:取出直属下级数据(左值大于lft_p,右值小于rgt_p,深度等于lv_p+1)中右值的最大值,命名为lft_i

      if (lft_i == null)
      	lft_i = lft_p + 1
      else 
      	lft_i += 1
      
    • 上级不存在:取出顶层数据(lv=1)中右值的最大值,命名为lft_i

      if (lft_i == null)
      	lft_i = 1
      else 
      	lft_i += 1
      
  2. 更新现有节点

    -- 左值大于lft_i的数据,左值全部+2
    update xx set lft = lft +2 where lft > lft_i
    -- 右值大于等于lft_i的数据,右值全部+2
    update xx set rgt = rgt +2 where rgt >= lft_i
    
  3. 插入新节点

    insert into xx (lft,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wxl302947229

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值