我不知所措,我看不出这样简单的原因,这不会起作用:
CREATE PROCEDURE test()
BEGIN
DECLARE var INT;
SET var = 0;
END
我真的只是测试这个,因为我似乎根本无法创造任何东西.我得到的错误信息是:
[ERROR in query 1] 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
第3行是DECLARE语句.有任何想法吗?
最佳答案
在任何SQL平台中创建存储过程时,这是一个常见的分隔符问题.默认分隔符是;所以当MySQL看到第一个;在第3行,它解析为语句的结尾.您必须将DELIMITER更改为其他内容,并使用新的DELIMITER标记存储过程的结尾.
-- Change DELIMITER TO // instead of ;
DELIMITER //
CREATE PROCEDURE test()
BEGIN
DECLARE var INT;
SET var = 0;
END
//
-- Mark the stored procedure as one statement
DELIMITER ;
-- Change delimiter back to ;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。