mysql 递归查询的方法

表结构和数据

CREATE TABLE `class` (
  `classid` int(11) NOT NULL AUTO_INCREMENT,
  `banji` int(11) DEFAULT NULL COMMENT '0',
  `nianji` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`classid`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of class
-- ----------------------------
INSERT INTO `class` VALUES ('1', '0', '1');
INSERT INTO `class` VALUES ('2', '1', '2');
INSERT INTO `class` VALUES ('3', '1', 'f');
INSERT INTO `class` VALUES ('4', '2', 'd');
INSERT INTO `class` VALUES ('5', '3', 's');
INSERT INTO `class` VALUES ('6', '0', 'a');
INSERT INTO `class` VALUES ('7', '6', 'q');
INSERT INTO `class` VALUES ('8', '7', 'h');
INSERT INTO `class` VALUES ('9', '5', '额');
INSERT INTO `class` VALUES ('10', '4', '121');

笨办法:一级写一个查询结果联合起来

SELECT * from class WHERE classid =1
UNION
SELECT * FROM class where banji in(SELECT classid from class  WHERE classid =1 )
UNION 
SELECT * FROM class where banji in (SELECT classid FROM class where banji in(SELECT classid from class  WHERE classid =1))

使用函数方法:创建函数来获取个节点的值

CREATE FUNCTION `selectTree`(`id` int)
 RETURNS varchar(2000)
BEGIN
	#Routine body goes here...
	DECLARE st VARCHAR(4000);
	DECLARE	stcc VARCHAR(2000);
#给st赋初值不能null,null会没有返回值
	set st='';
	set stcc=id;
#判断stcc的是否为null
	WHILE stcc is not NULL DO
#拼接字符串赋值给st
	SET st=CONCAT(st,',',stcc);
	SELECT GROUP_CONCAT(classid) INTO stcc FROM class where FIND_IN_SET(banji,stcc)>0;
END WHILE;
	RETURN st;
END;
调用函数查出结果
SELECT * from  class where classid in (SELECT a.ban FROM class a,class b where a.banji=b.classid)  and banji=0




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丵鹰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值