运行 更改计数器变量后循环停止
Running the loop stops after changing the Counter Variable
当我 运行 下面的代码时,它总是 returns 循环内两个变量的 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 并且循环停止。但是,在 table c 里面有执行循环的相关值。
- 循环中变量@i取值时出现问题
变化。
比如第一次执行循环,@i的值变成了3,table中有一个值为3的id c加上初始值4.
Tablec
的结构
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改变了[=25=的结果的return值] 在循环中更改其值后使用 @i 变量时声明为 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;
我希望它对其他人也有用。
当我 运行 下面的代码时,它总是 returns 循环内两个变量的 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 并且循环停止。但是,在 table c 里面有执行循环的相关值。
- 循环中变量@i取值时出现问题
变化。
比如第一次执行循环,@i的值变成了3,table中有一个值为3的id c加上初始值4.
Tablec
的结构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改变了[=25=的结果的return值] 在循环中更改其值后使用 @i 变量时声明为 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;
我希望它对其他人也有用。