查mysql执行sql队列_在T-SQL中用队列来遍历层级数据

在T-SQL中用队列来遍历层级数据 前几天看了《The Guru's Guide To Transact SQL》(中文翻译是Transact-SQL 权威指南),里面介绍的一个查询是关于层级结构的,处理的方式本质就是队列,遍历的结果就像遍历二叉树的中先序遍历,很有趣。 待查询的表结构如下

在T-SQL中用队列来遍历层级数据

前几天看了《The Guru's Guide To Transact SQL》(中文翻译是Transact-SQL 权威指南),里面介绍的一个查询是关于层级结构的,处理的方式本质就是队列,遍历的结果就像遍历二叉树的中先序遍历,很有趣。

待查询的表结构如下:

cb0a651b2680d4f882d6a2f333c9006a.png

每个层节点都分配一个唯一的ID、节点的名称、上一个父节点的ID。现在,要做的是查找指定节点ID下所有的子节点,比如对于ID为3的节点来说,它的查询结果ID 集为{5,6,7,8,9,10,11,12,13}。下面就是关键了,写了个存储过程,方便重用。

f3c4b23723f586d731923dcbb9645ec0.png

简单介绍下它的原理,美国服务器,首先,将自身加载到队列中,免备案空间,初始化队列。每次都从队列中弹出一个值,并把值写入到结果集中,再把属于值的子节点塞到队列中。如果成功塞入,网站空间,就进入下一个层级,很类似于遍历树形结构使用队列处理的情况。在处理队列时,如果发现当前层以没有元素需要处理了,则返回处理它的上一层,就是语句IF EXISTS(SELECT * FROM #queue where lvl=@lvl) BEGIN。。。END ELSE SET @lvl = @lvl-1,也是退出WHILE循环的条件。

下面看看执行的结果:

cb42821a6581d101da9d2995a7420fb9.png

总结一下,TSQL是相当灵活的,很多数据结构中的算法都可以结合表来实现,最后实现的语句虽然复杂了点,不过效率一般较高。发帖辛苦,请支持下。

demo的sql语句:

posted on

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值