作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
您好,我有以下存储过程
DROP PROCEDURE IF EXISTS `p25`$$
CREATE DEFINER=`root`@`%` PROCEDURE `p25`()
BEGIN
DECLARE b BOOLEAN;
DECLARE a VARCHAR(10);
DECLARE cur_1 CURSOR FOR SELECT t FROM sample_table;
DECLARE CONTINUE HANDLER FOR NOT FOUND
SET b = TRUE;
OPEN cur_1;
lbl:LOOP
IF b = TRUE THEN
LEAVE lbl;
END IF;
IF NOT b= TRUE THEN
FETCH cur_1 INTO a;
END IF;
END LOOP;
CLOSE cur_1;
END$$
select 语句实际上返回 5 行但在获取一行后,上述过程不会循环遍历其他行。并且 b 值永远不会设置为 true,因此它将进入无限循环。我的代码有什么问题吗?请有人帮助我..
我找到了解决方案,感谢您的帮助。我认为我检查值的方式是错误的。所以现在,我想根据获取的行值从其他表中获取值。我怎样才能打印结果||当前行值||从其他表中获取的值||作为获取所有行的结果。
最佳答案
其中一个原因可能是您可能再次在游标内使用了 select into 语句,这会将游标循环内那些嵌套的 select 语句的处理程序值设置为 1。您可以在内部使用 select 语句后将处理程序值重置为 0,并将处理程序条件移动到 FETCH 命令旁边。示例:
...
BEGIN
DECLARE cursor_finished INTEGER DEFAULT 0;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET cursor_finished = 1;
...
open table_cursor;
get_row: LOOP
FETCH table_cursor INTO v_variable1, v_variable3;
IF cursor_finished = 1 THEN
LEAVE get_row;
END IF;
....
Select id into v_id from sometable; -- this sets cursor_finished to 1.
SET cursor_finished = 0; -- hence reset this value for cursor.
....
END
关于mysql - DECLARE CONTINUE HANDLER FOR NOT FOUND 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7712110/
我是一名优秀的程序员,十分优秀!