mysql.cursors,MySql Cursor – 创建一个过程

我正在尝试第一次创建游标.我看过文档,我理解这个概念,但我似乎无法得到它甚至被宣布…

我正在使用:

> MySql 5.1.41

> SqlYog作为经理

>(在xampp安装上本地运行)

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;

我马上得到错误:

错误代码:1064

You have an error in your SQL syntax;

check the manual that corresponds to

your MySQL server version for the

right syntax to use near ” at line 3

以及其他一些人,

这对我没有任何意义,任何善良的灵魂都可以帮助我吗?

谢谢

所以我让样本查询工作(感谢ajreal),重置DELIMITER.但是当我运行我的查询时:

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;##

我得到:

错误代码:1064

You have an error in your SQL syntax;

check the manual that corresponds to

your MySQL server version for the

right syntax to use near ‘DECLARE done

INT DEFAULT 0; DECLARE cur CURSOR FOR

SELECT uid FROM viewpoints; ‘ at line

1

我的天啊,这很难……

解决方法:

你忘记将分隔符重置为NOT;

delimiter ##

...

end##

需要在分隔符后放置一个空格

结束END不需要;

标签:mysql,cursor,mysql-error-1064

来源: https://codeday.me/bug/20190621/1256413.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值