为什么这个declare会报错

 

char(20),括号前面不能有空格。

create PROCEDURE test()
BEGIN
    declare val char(20);
    set val = 'hello';
    select a ;
end;

 

mysql只能在函数或存储过程中声明变量,所以你要将代码改成如下:

CREATE PROCEDURE p()
BEGIN
DECLARE VAL CHAR(20);
SET VAL = 'HELLO';
SELECT VAL;
END;

 

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632