DELIMITER $$
DROP PROCEDURE IF EXISTS `p3` $$
CREATE PROCEDURE p3()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE table_name VARCHAR(255);
DECLARE stmt varchar(200);
DECLARE cur1 CURSOR FOR select table_name from information_schema.tables;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
CREATE PROCEDURE p3()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE table_name VARCHAR(255);
DECLARE stmt varchar(200);
DECLARE cur1 CURSOR FOR select table_name from information_schema.tables;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
OPEN cur1;
REPEAT
FETCH cur1 INTO table_name;
select table_name;
UNTIL done = 1
END REPEAT;
CLOSE cur1;
END $$
FETCH cur1 INTO table_name;
select table_name;
UNTIL done = 1
END REPEAT;
CLOSE cur1;
END $$
DELIMITER ;
查询出来的结果都为空, 最后发现变量table_name与游标定义中的table_name重复,修改变量table_name为其它的名字。 但具体内在的发生机制还不太清楚。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/16582684/viewspace-690398/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/16582684/viewspace-690398/
本文介绍了一个MySQL存储过程中因游标变量名重复导致的问题及解决方案。通过一个具体的例子展示了如何避免变量名与游标定义中的字段名重复,并解释了这种冲突可能带来的影响。
2197

被折叠的 条评论
为什么被折叠?



