3
내가 MySQL의에서 재귀 한계에 직면 다음 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를 사용하지 않고 :
"SET @@ SESSION.max_sp_recursion_depth = 255; " 재귀없이 계층 구조 데이터와 상호 작용할 수 있습니다.