关于树型结构的SQL查询优化

1 篇文章 0 订阅

前情

在以往,我们查询某个区域下方的数据时,需要获得所有区域Id,然后带入SQL中使用IN关键字来实现对该节点级节点一下的数据的查询。

如何修改使得不要嵌套这么多的Id也能实现该操作。

处理

  1. 可以考虑再区域数据与关联到区域数据的表中添加一个字符串字段(此处取名AraeCode)。
  2. AraeCode的值是唯一值。
  3. 咱们在生成新区域时,可以套用父节点的AreaCode并在末尾最佳唯一字符串,拼接成新字符串。
  4. 然后咱们给AreaCode在数据库中建立索引。
  5. 由于咱们每次都在末尾追加字符串,使得查询能够走索引。
  6. 索引失效的一个场景就是:like ‘%f1’。
  7. 从而提升效率

举例

[
    {"Id":1,"Name":"四川","PId":0,"AreaCode":"f1"},
    {"Id":2,"Name":"成都","PId":1,"AreaCode":"f1gD"},
    {"Id":3,"Name":"自贡","PId":1,"AreaCode":"f13c"},
    {"Id":4,"Name":"绵阳","PId":1,"AreaCode":"f1ac"},
    {"Id":5,"Name":"成都区-0","PId":2,"AreaCode":"f1gDzc"}
]

当我们想查询四川下面的数据时

SELECT 
	* 
FROM Device
WHERE AreaCode like 'f1%'

当我们想查询成都下面的数据时

SELECT 
	* 
FROM Device
WHERE AreaCode like 'f1gD%'

以此类推通过like来优化查询

弊端

如果区域表的数据节点经常改变的话,那需要额外维护其他表和区域表的AreaCode。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值