mysql查询分类的所有子节点

这篇博客探讨了一种SQL查询方法,用于从classify表中获取指定分类及其所有子分类的ID。通过使用变量@pids和find_in_set函数,查询确保了父分类在子分类之前,但存在先创建子分类后创建父分类时查询不到的问题。解决方案提到使用存储过程来解决此问题。
摘要由CSDN通过智能技术生成

项目中有个多级分类的表,需要查询某个分类下的所的子分类 classify表在这里插入图片描述
select t.* , if(find_in_set(pid, @pids) > 0, @pids := concat(@pids, ‘,’, id), ‘top’) as isExist
from classify t,(select @pids := ‘a’) t2
having isexist != ‘top’

这条sql的意思是查询表所有行,定义临时变量@pids ,如果那一行的pid在这个变量@pids中就把该行的id添加到@pids中,最后这个@pids变量就是所该分类和所有子分类id的集合

这个查询有个天然的缺陷就是子分类行数据要在父分类的行数据后,如果是先插入的子分类,那这条子分类就查询不到,不过一般都是先创建的父分类后才有的子分类所以查询到的是所有子分类数据,(如果有子分类早创建的情况使用存储过程比较好解决)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值