mysql递归死循环查询_MySQL 递归查询实践总结

本文介绍了如何在MySQL中进行递归查询,以解决查询表结构中存在父子关系记录的问题。提供了两种查询实现:1) 查询指定记录的所有祖先记录,并按层级返回祖先记录的name;2) 查询指定parent_id关联的所有后辈记录id。同时,文章强调了防止递归死循环的关键代码,确保查询的正确性。
摘要由CSDN通过智能技术生成

MySQL复杂查询使用实例

By:授客QQ:1033553122

表结构设计

SELECT id, `name`, parent_id FROM `tb_testcase_suite`

1da2429a950c569a71d9db1c5ed87707.png

说明:

parent_id值关联表自身id列的值,如果其值为-1,则表示该记录不存在父级记录,否则表示该记录存在父级记录(假设parent_id值为5,则父级记录id为5),暂且把该记录自身称之为子记录,父级及父父级的记录称之为祖先记录,子级及子子级记录称之为后辈记录

查询需求

1) 根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name

2) 根据指定parent_id,查询其关联的的所有后辈记录id

查询实现

通过函数调用实现

1)根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name

# 向上递归

DROP FUNCTION IF EXISTS querySuitePath;

DELIMITER ;;

CREATE FUNCTION querySuitePath(suiteId INT)

RETURNS VARCHAR(21845)

BEGIN

DECLARE suitePath VARCHAR(21845);

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值