在 mysql 中存储函数创建错误 #1064
store function creation error in mysql #1064
我尝试创建一个函数,即如果用户名存在,将 return 随机数和字符作为单个字符串,但我尝试了下面的代码,抛出如下语法错误,你能帮忙找到问题,我知道在声明字符串和 returning 字符串时有问题,但找不到问题所在。感谢提前回复
DELIMITER //
create function verifyEmail(userName varchar(25))
RETURNS TEXT
BEGIN
if EXISTS(select * from userdetails where name = userName)
then
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1));
return @randomPass;
else
return "not_exist";
end if;
end //
DELIMITER //
#1064 - 您的 SQL 语法有误;查看与您的 MySQL 服务器版本相对应的手册,了解在第 6
行 'select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(ra' 附近使用的正确语法
您在这一行缺少结尾 )
:
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1);
应该是
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1));
万岁,终于找到答案了。下面的代码将有助于解决问题
DELIMITER //
create function verifyEmail(userName varchar(25))
RETURNS TEXT
BEGIN
DECLARE randomPass VARCHAR(8);
if EXISTS(select id from userdetails where name = userName)
THEN
SET randomPass = concat( char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65));
return randomPass;
else
return "not_exist";
end if;
end //
DELIMITER //
我尝试创建一个函数,即如果用户名存在,将 return 随机数和字符作为单个字符串,但我尝试了下面的代码,抛出如下语法错误,你能帮忙找到问题,我知道在声明字符串和 returning 字符串时有问题,但找不到问题所在。感谢提前回复
DELIMITER //
create function verifyEmail(userName varchar(25))
RETURNS TEXT
BEGIN
if EXISTS(select * from userdetails where name = userName)
then
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1));
return @randomPass;
else
return "not_exist";
end if;
end //
DELIMITER //
#1064 - 您的 SQL 语法有误;查看与您的 MySQL 服务器版本相对应的手册,了解在第 6
行 'select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(ra' 附近使用的正确语法您在这一行缺少结尾 )
:
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1);
应该是
SELECT @randomPass := select concat( char(round(rand()*36)+1), char(round(rand()*36)+1), char(round(rand()*36)+1));
万岁,终于找到答案了。下面的代码将有助于解决问题
DELIMITER //
create function verifyEmail(userName varchar(25))
RETURNS TEXT
BEGIN
DECLARE randomPass VARCHAR(8);
if EXISTS(select id from userdetails where name = userName)
THEN
SET randomPass = concat( char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65),char(rand()*25+65));
return randomPass;
else
return "not_exist";
end if;
end //
DELIMITER //