mysql - 更改计数器变量后停止运行循环
问题描述
当我运行以下代码时,它总是为循环内的两个变量返回一个NULL值。
SET @c = '';
SET @i = 4;
REPEAT
SET @c = CONCAT(
' -> ',
(
SELECT name
FROM c
WHERE id = @i
),
@c
);
SET @i = (
SELECT pid
FROM c
WHERE id = @i
);
UNTIL TRIM(COALESCE(@i, '')) = ''
END REPEAT;
循环必须至少运行 4 次;但在第二次运行中,循环的运行结束。
该值是在第一次执行循环时为变量设置的;但是在循环的第二次运行中,两者的值都变为 NULL 并且循环停止。但是,在表c中,有用于执行循环的相关值。
- 当循环中变量@i的值发生变化时,就会出现问题。
比如第一次执行循环,@i 的值变成了 3 ,表c中除了初始值 4 之外,还有一个值为 3 的 id
表c的结构
CREATE TABLE c (
id int UNSIGNED NOT NULL AUTO_INCREMENT,
name varchar(50) NOT NULL,
pid int UNSIGNED DEFAULT NULL,
PRIMARY KEY (id)
) ENGINE = INNODB,
AUTO_INCREMENT = 1,
CHARACTER SET utf8mb4,
COLLATE utf8mb4_unicode_ci;
ALTER TABLE c
ADD CONSTRAINT c_pid_foreign FOREIGN KEY (pid) REFERENCES c (id);
INSERT INTO c(id, name, pid)
VALUES (1, '1st', NULL),
(2, '2nd', 1),
(3, '3rd', 2),
(4, '4th', 3);
预先感谢人们为解决这个问题而给予的良好合作。
解决方案
大约一天多后,我终于能够解决我的问题;当然,我不明白这个问题的原因,我也不知道为什么MySQL在循环内更改@i变量的值后,在使用@i变量时,将SELECT语句结果的返回值更改为NULL?!!!
解决方法如下:
SET @d = '';
SET @j = 4;
REPEAT
SELECT @c := name
FROM c
WHERE id = @j;
SET @d = CONCAT(' -> ', @c, @d);
SELECT @i := pid
FROM c
WHERE id = @j;
SET @j = @i;
UNTIL TRIM(COALESCE(@j, '')) = ''
END REPEAT;
这是解决此问题的最佳方法:
SET @d = '';
SET @j = 4;
REPEAT
SELECT name INTO @c
FROM c
WHERE id = @j;
SET @d = CONCAT(' -> ', @c, @d);
SELECT pid INTO @i
FROM c
WHERE id = @j;
SET @j = @i;
UNTIL TRIM(COALESCE(@j, '')) = ''
END REPEAT;
我希望它对其他人也有用。
推荐阅读
- database - 用于匹配条件子集的 PostgresSQL 查询
- python-3.x - matplotlib.animation - 在曲线上移动点
- c++ - GNU LD 在使用 C++ 标准库时出错
- angular - NX.Dev 从 11 迁移到 12 失败并显示“EBUSY:资源繁忙或锁定”
- python - 不可更改的 Python 类实例属性
- javascript - 为什么在 map() 方法中使用 { } 会返回未定义的数组?
- ios - 将 HTTP 请求正文放入“数据”:{}?
- java - 如何反序列化列表列表?
- css - CSS过渡不适用于标签
- javascript - Java 脚本图像更改