过程参数问题 - Mysql 5.1 SQL Error 1064
以下内容适用于MYSQL 5.5 windows,不适用于MYSQL 5.1,ubuntu lucid
DELIMITER $$
CREATE PROCEDURE `queueup`( IN groupsize INT, OUT done INT)
BEGIN
DECLARE room INT;
SET room = -1;
UPDATE queue SET status = 'PLACED', assigned_room = room WHERE status = 'WAITING' ORDER BY queue_position ASC LIMIT groupsize;
END $$
SQL错误1064:
您的 SQL 语法有错误;检查手册 与您的 MySQL 服务器版本相对应,以便使用正确的语法 接近'groupsize;
The following works in MYSQL 5.5 windows, doesn't work in MYSQL 5.1, ubuntu lucid
DELIMITER $
CREATE PROCEDURE `queueup`( IN groupsize INT, OUT done INT)
BEGIN
DECLARE room INT;
SET room = -1;
UPDATE queue SET status = 'PLACED', assigned_room = room WHERE status = 'WAITING' ORDER BY queue_position ASC LIMIT groupsize;
END $
SQL Error 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 'groupsize;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
在 MySQL 5.5 中,LIMIT 子句可以与变量一起使用;在你的情况下,“groupsize”是一个变量。
来自 参考 - 在存储的程序中,LIMIT 参数从 MySQL 5.5.6 开始,可以使用整数值例程参数或局部变量来指定。
In MySQL 5.5 LIMIT clause can be used with variables; in your case 'groupsize' is a variable.
From the reference - Within stored programs, LIMIT parameters can be specified using integer-valued routine parameters or local variables as of MySQL 5.5.6.