视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL查询Summary<无限级分类,递归检索或删除父类下的所_MySQL
2020-11-09 18:17:35 责编:小采
文档

bitsCN.com 一张无限级的分类表,简列主要表字段主键FID,父类ID字段FPID。 检索数据集的SQL语句 with a as(select FID from 表 where FID ='值'union allselect x.FID from 表 x,a where x.FPID =a.FID )select * from a删除数据集的SQL语句 with a as(select FID from 表 where FID ='值'union allselect x.FID from 表 x,a where x.FPID =a.FID )delete from 表 where FID in(select FID from a )
1.其中x可以理解为类似a别名或者join关联语句里面的从表名 2.如果你像这样改写检索语句 with a as(select * from 表 where FID='值'union allselect a.* from ArticleType x,a where x.FPID=a.FID)select * from a 可能会出现"语句被终止。完成执行语句前已用完最大递归 100"报错。 解决办法如下:

在union两检索出来的数据集时它们字段的个数/类型要相同/对应。这是我的理解 with a as(select 字段1,字段2,字段3,字段4.. from 表 where FID='值'union allselect x.字段1,x.字段2,x.字段3,x.字段4..from 表 x,a where x.FPID=a.FID)select * from a PS:之前看过一些前辈们的blog,我记得其中有一篇日志里面有这样的一句话:"分享别人是一点,但别人能给予你两点..."。我知道每个人的经验经历和技术能力都不一样,像我这样的菜鸟虽然毕业工作一年时间不到,还有很多的不足和需要学习的地方,但是岁月不饶人,平时工作实践中遇到的问题有机会和时间就写出来整理一下思绪,积累一点,是一点。 作者 wisonlee bitsCN.com

下载本文
显示全文
专题