Mysql刷题笔记 12.25 递归创建路径

Mysql练习

-- 12.25 递归创建路径
T1225
+------+------+
| ID   | PID  |
+------+------+
|    1 |    0 |
|    2 |    1 |
|    3 |    2 |
|    4 |    3 |
+------+------+
结果
+------+------+------------+
| ID   | PID  | PATH       |
+------+------+------------+
|    1 |    0 | 1          |
|    2 |    1 | 1->2       |
|    3 |    2 | 1->2->3    |
|    4 |    3 | 1->2->3->4 |
+------+------+------------+

DROP FUNCTION IF EXISTS f1225;
DELIMITER //  -- 修改结束符

CREATE FUNCTION f1225(Id INT)
RETURNS VARCHAR(4000)
BEGIN
	DECLARE sTemp VARCHAR(4000);
	DECLARE idTemp INTEGER;
	SET sTemp='1';
	SET idTemp = 1;
	WHILE idTemp < Id DO
		SET sTemp= CONCAT(STemp,'->',cast((idTemp+1) as CHAR));
		SET idTemp = idTemp +1;
	END WHILE;
	RETURN sTemp;
END
//
DELIMITER ;

SELECT ID,PID,f1225(ID) AS PATH FROM T1225;


WITH RECURSIVE TEST_CTE AS
(
	SELECT t.ID,t.PID,Cast(ID AS CHAR) AS PATH
  FROM T1225 t
  WHERE t.ID=1
  UNION ALL
  SELECT p.ID,p.PID,CONCAT(CTE.PATH,"->",Cast(p.ID AS CHAR)) AS PATH
  FROM T1225 p
  INNER JOIN TEST_CTE CTE ON p.PID = CTE.ID
)
SELECT * FROM TEST_CTE

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值