mysql⽤declare会报错_mysql导⼊存储过程时declare报错的
问题解决
在导⼊存储过程时经常遇见下列DECLARE报错的问题:
Error Code : 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL rver version for the right syntax to u near '' at line 3
(0 ms taken)
有多少个DECLARE就会报多少次,然后后⾯就是取不到变量的报错。
这个原因是没有定义delimiter
如下的会报错:
CREATE PROCEDURE p8()
BEGIN
DECLARE a INT;
DECLARE b INT;
SET a = 5;
SET b = 5;
lect pkid,name,urGroup_desc,parent_id,group_state from T_VSM_SECPOLICY_USERGROUP;
END;
错误信息:
饺子照片Error Code : 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL rver version for the right syntax to u near '' at line 3
(0 ms taken)
。。。。
添加了delimiter后就不报了
delimiter //
CREATE PROCEDURE p8()
BEGIN
DECLARE a INT;
DECLARE b INT;
SET a = 5;
SET b = 5;
declare cur0 cursor for lect pkid from T_VSM_SECPOLICY_USERGROUP; --这⾥为什么报错?
END//
具体原因可以查看mysql的官⽅⼿册
中的创建存储过程章节⾥的下列内容,不能被忽视了:
下⾯是⼀个使⽤OUT参数的简单的存储程序的例⼦。例⼦为,在 程序被定义的时候,⽤mysql客户端delimiter命令来把语句定界符从 ;变为//。这就允许⽤在 程序体中的;定界符被传递到服务器⽽不是被mysql⾃⼰来解释。头脑的英文
mysql> delimiter //
mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)
-> BEGIN
-> SELECT COUNT(*) INTO param1 FROM t;
-> END
怎样查字典-> //
Query OK, 0 rows affected (0.00 c)
mysql> delimiter ;
mysql> CALL simpleproc(@a);
Query OK, 0 rows affected (0.00 c)
mysql> SELECT @a;
+------+
| @a |
+------+
| 3 |
+------+
1 row in t (0.00 c)
欣喜若狂的意思
当使⽤delimiter命令时,你应该避免使⽤反斜杠(‘\’)字符,因为那是MySQL的 转义字符。
下列是⼀个例⼦,⼀个采⽤参数的函数使⽤⼀个SQL函数执⾏⼀个操作,并返回结果:
绽放作文mysql> delimiter //
mysql> CREATE FUNCTION hello (s CHAR(20)) RETURNS CHAR(50)
怀念姥姥-> RETURN CONCAT('Hello, ',s,'!');
-> //
Query OK, 0 rows affected (0.00 c)
mysql> delimiter ;
mysql> SELECT hello('world');
+----------------+
| hello('world') |
+----------------+
| Hello, world! |
+----------------+
1 row in t (0.00 c)
bobo发型如果在存储函数中的RETURN语句返回⼀个类型不同于在函数的RETURNS⼦句中指定类型的值,返回值被强制为恰当的类型。⽐如,如果⼀个函数返回⼀个ENUM或SET值,但是RETURN语句返回⼀个整数,对于SET成员集的相应的ENUM成员,从函数返回的值是字符串。
还有后⾯的内容也说明了这个问题
20.2.7. BEGIN ... END复合语句
[begin_label:] BEGIN
[statement_list]
END [end_label]
存储⼦程序可以使⽤BEGIN ... END复合语句来包含多个语句。statement_list 代表⼀个或多个语句的
列表。statement_list之内每个语句都必须⽤分号(;)来结尾。
复合语句可以被标记。除⾮begin_label存在,否则end_label不能被给出,并且如果⼆者都存在,他们必须是同样的。
请注意,可选的[NOT] ATOMIC⼦句现在还不被⽀持。这意味着在指令块的开始没有交互的存储点被设置,并且在上下⽂中⽤到的BEGIN ⼦句对当前交互动作没有影响。
使⽤多重语句需要客户端能发送包含语句定界符;的查询字符串。这个符号在命令⾏客户端被⽤delimiter命令来处理。改变查询结尾定界符; (⽐如改变为//)使得; 可被⽤在⼦程序体中。
总结起来就是因为存储过程⾥包含很多含缺省界定符号“;”的语句,如果不重新定义界定符的话,就只能以“;”为界定符⼀句⼀句的发给Mysql服务端解析,那么存储过程的第⼀句话肯定就语法错误了:
CREATE PROCEDURE p8()
BEGIN
DECLARE a INT;
然后后⾯的
DECLARE b INT;
城市桥梁也会报错,因为⼿册中规定DECLARE必须出现在BEGIN 和 EDN之间,且在其它所有语句之前。这个单独出现的DECLARE b INT;就会报语法错误了。
现在明⽩了吧。。。