• ADADADADAD

    MySQL 递归查询总结[ mysql数据库 ]

    mysql数据库 时间:2024-12-24 19:10:25

    作者:文/会员上传

    简介:

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

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    说明:

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

    查询需求

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

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

    查询实现

    通过函数调用实现

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

    #向下递归

    DROP FUNCTION IF EXISTS queryChildrenSuiteIds;

    DELIMITER;;

    CREATE FUNCTION queryChildrenSuiteIds(suiteId INT)

    RETURNS VARCHAR(4000)

    BEGIN

    DECLARE childSuiteIds VARCHAR(4000);

    DECLARE parentSuiteIds VARCHAR(4000);

    SET childSuiteIds='';

    SET parentSuiteIds=CAST(suiteId AS CHAR);

    WHILE parentSuiteIds IS NOT NULL DO

    SET 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);

    MySQL 递归查询总结.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysql总结查询