MySQL 递归查询总结

来源:这里教程网 时间:2026-03-01 15:06:08 作者:

说明:parent_id值关联表自身id列的值,如果其值为-1,则表示该记录不存在父级记录,否则表示该记录存在父级记录(假设parent_id值为5,则父级记录id为5),暂且把该记录自身称之为子记录,父级及父父级的记录称之为祖先记录,子级及子子级记录称之为后辈记录查询需求1)根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name2)根据指定parent_id,查询其关联的的所有后辈记录id查询实现通过函数调用实现1)根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name#向下递归DROP FUNCTION IF EXISTS queryChildrenSuiteIds;DELIMITER;;CREATE FUNCTION queryChildrenSuiteIds(suiteId INT)RETURNS VARCHAR(4000)BEGINDECLARE childSuiteIds VARCHAR(4000);DECLARE parentSuiteIds VARCHAR(4000);SET childSuiteIds='';SET parentSuiteIds=CAST(suiteId AS CHAR);WHILE parentSuiteIds IS NOT NULL DOSET childSuiteIds=CONCAT(parentSuiteIds,',',childSuiteIds);SELECT GROUP_CONCAT(id)INTO parentSuiteIds FROM tb_testcase_suite WHERE FIND_IN_SET(parent_id,parentSuiteIds)>0;END WHILE;RETURN childSuiteIds;END;;DELIMITER;#调用SELECT queryChildrenSuiteIds(5);

相关推荐