And*_*dez 5 mysql cursor mysql-error-1064
我正在尝试第一次创建一个游标。我看了文档,我理解了这个概念,但是我什至无法声明它……
我正在使用:
即使复制粘贴在http://dev.mysql.com/doc/refman/5.1/en/cursors.html中找到的示例,
CREATE PROCEDURE curdemo()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE a CHAR(16);
DECLARE b,c INT;
DECLARE cur1 CURSOR FOR SELECT id,data FROM test.t1;
DECLARE cur2 CURSOR FOR SELECT i FROM test.t2;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
OPEN cur1;
OPEN cur2;
read_loop: LOOP
FETCH cur1 INTO a, b;
FETCH cur2 INTO c;
IF done THEN
LEAVE read_loop;
END IF;
IF b < c THEN
INSERT INTO test.t3 VALUES (a,b);
ELSE
INSERT INTO test.t3 VALUES (a,c);
END IF;
END LOOP;
CLOSE cur1;
CLOSE cur2;
END;
Run Code Online (Sandbox Code Playgroud)
我马上收到错误:错误代码:1064
您的SQL语法有误;检查与您的MySQL服务器版本相对应的手册,以在第3行的''附近使用正确的语法
还有很多其他人
这对我来说没有任何意义,有什么好心的人可以帮助我吗?
谢谢
所以我通过重置DELIMITER使示例查询可以工作(感谢ajreal)。但是当我运行查询时:
DELIMITER##
CREATE PROCEDURE RetiraPoints()
BEGIN
DECLARE userid BIGINT;
DECLARE done INT DEFAULT 0;
DECLARE cur CURSOR FOR SELECT uid FROM viewpoints;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
OPEN cur;
read_loop: LOOP
FETCH cur INTO userid;
IF done THEN
LEAVE read_loop;
END IF;
INSERT INTO points (iduser, points, pointcat) VALUES (uid, -1, 1), (userid, -1, 2), (userid, -1, 3), (userid, -1, 4), (userid, -1, 5), (userid, -1, 6);
END LOOP;
CLOSE cur;
END;##
Run Code Online (Sandbox Code Playgroud)
我得到:错误代码:1064
您的SQL语法有误;检查与您的MySQL服务器版本相对应的手册,以在'DECLARE done INT DEFAULT 0附近使用正确的语法;从观点出发,将SELECT uid用作当前游标;'在第1行
天哪,这很难...
您忘记将分隔符重置为NOT ;
delimiter ##
...
end##
Run Code Online (Sandbox Code Playgroud)
需要在分隔符后面添加一个空格
而且结局END不需要;
| 归档时间: |
|
| 查看次数: |
13223 次 |
| 最近记录: |