您好,欢迎访问代理记账网站
移动应用 微信公众号 联系我们

咨询热线 -

电话 15988168888

联系客服
  • 价格透明
  • 信息保密
  • 进度掌控
  • 售后无忧

mysql查询分类的所有子节点

项目中有个多级分类的表,需要查询某个分类下的所的子分类 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的集合

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


分享:

低价透明

统一报价,无隐形消费

金牌服务

一对一专属顾问7*24小时金牌服务

信息保密

个人信息安全有保障

售后无忧

服务出问题客服经理全程跟进