MySQL的存储过程不支持递归

本文介绍了一个MySQL中关于递归存储函数的问题案例。该案例尝试创建一个检查资产组镜像关系的递归函数,但遇到递归存储函数和触发器不允许的错误。文章详细展示了SQL脚本内容,并指出在MySQL中递归存储函数是不被允许的。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


-- FUNCTION check_asset_group_mirror_relationship

DROP FUNCTION IF EXISTS check_asset_group_mirror_relationship;
DELIMITER |
CREATE FUNCTION check_asset_group_mirror_relationship(group_id bigint(20)) RETURNS int
BEGIN
DECLARE group_type varchar(255);
DECLARE mirror_flag int default 0;
DECLARE parent_flag int default 0;
DECLARE parent_group_id bigint(20);
DECLARE done int default 0;
DECLARE parent_group_ids CURSOR FOR select agr.parent_asset_group_id from asset_group_relation agr where agr.child_asset_group_id = group_id;
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
select asset_group_type into group_type from asset_group ag
where ag.id=group_id;
IF group_type = 'GROUP' THEN
SET group_type = 'ASSET_GROUP';
END IF;
select count(1) into mirror_flag from mirror_relationship mr
where mr.group_type = group_type and mr.group_id = group_id;
IF mirror_flag = 0 THEN
select count(1) into parent_flag from asset_group_relation agr
where agr.child_asset_group_id = group_id;
IF parent_flag > 0 THEN
OPEN parent_group_ids;
REPEAT
FETCH parent_group_ids INTO parent_group_id;
IF NOT done THEN
IF mirror_flag = 0 THEN
SET mirror_flag = check_asset_group_mirror_relationship(parent_group_id);
END IF;
END IF;
UNTIL done END REPEAT;
CLOSE parent_group_ids;
END IF;
END IF;
RETURN mirror_flag;
END|
DELIMITER ;


然后去调用check_asset_group_mirror_relationship(2),MySQL报Error 1424: Recursive stored functions and triggers are not allowed.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值