MySql::存储过程递归

标签 mysql stored-procedures recursion

我如何重写以下 SP 以面对 MySQL 中的递归限制:

CREATE DEFINER = `root`@`localhost` PROCEDURE `SP_DeleteParentDirectory`(pParentID INT,pIsFolder INT,pReferenceID INT)
BEGIN   
SET @@SESSION.max_sp_recursion_depth = 255;
    SET @IsFolder= NULL;
    SET @ChildID= NULL;
    SET @ReferenceID= NULL;
    IF ( pIsFolder= 2) THEN
                SELECT  FileID INTO @ChildID FROM filesinfo WHERE ParentID= pParentID LIMIT 1;
                WHILE (@ChildID IS NOT NULL) DO
                         SELECT  filesinfo.IsFolder,filesinfo.ReferenceID INTO @IsFolder,@ReferenceID FROM filesinfo WHERE filesinfo.FileID = @ChildID;
                        CALL SP_DeleteParentDirectory(@ChildID,@IsFolder,@ReferenceID);             
                        SELECT filesinfo.FileID INTO @ChildID FROM filesinfo WHERE ParentID= pParentID LIMIT 1;
                END While;
    END IF;
    DELETE FROM filesinfo Where  filesinfo.FileID= pParentID;
    IF EXISTS( SELECT  * FROM  filesrefrences WHERE filesrefrences.ReferenceID = pReferenceID AND filesrefrences.RefrenceCount>1) THEN
            UPDATE filesrefrences
            SET RefrenceCount= RefrenceCount-1 WHERE  filesrefrences.ReferenceID = pReferenceID;            
    ELSE            
            SET @ReferenceKey= NULL;
            Select filesrefrences.RefrenceKey INTO @ReferenceKey FROM filesrefrences WHERE filesrefrences.ReferenceID= pReferenceID;
            IF NOT EXISTS(SELECT * FROM deletefilesreferences WHERE deletefilesreferences.FileReference= @ReferenceKey) THEN
            INSERT INTO deletefilesreferences (deletefilesreferences.FileReference)VALUES(@ReferenceKey);
            END IF;
            DELETE FROM filesrefrences where filesrefrences.ReferenceID = pReferenceID;         
    END IF;
    -- CALL SP_DeleteFileInfo(pParentID,pReferenceID);      
    -- SELECT * FROM deletefilesreferences;
    -- CALL SP_GetDeletedReferences();
END;

不使用这个 sts :

设置@@SESSION.max_sp_recursion_depth = 255;” 我的意思是可以在不递归的情况下与层次结构数据交互。

最佳答案

如果设置 max_sp_recursion_depth,Mysql 允许在一个过程中最多有 255 次递归。

它有风险,因为将来某个时候所需的递归深度有可能超过 255。

因此,最好将函数替换为过程,使用 INOUT 变量作为 return_result。

关于MySql::存储过程递归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14315343/

相关文章:

mysql - 通过 Node.js 将重复键更新上的行批量插入到 mysql 中,同时还执行 mysql 函数

mysql - 为MySQL存储过程添加默认值为NULL的参数

tsql - 如何使用hierarchyid sql显示所有递归结果

swift - 如何编写一个通用的 Swift 扩展来深度合并两个词典?

mysql - 如何检查两个MySQL表中两个时间之间的差异?

MySQL 左连接带有附加的类似条件

php - 获取 .json 文件的正确格式

python - 从 sqlalchemy 核心中的函数调用中选择列

nhibernate - 如何使用 NHibernate 调用从多个表返回结果的过程?

javascript - 指定元素的深度