MySql中语句报错信息怎么看

14 篇文章 1 订阅

我们最常见的报错信息

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 'return returnTime;
  end' at line 13

单引号括起来的部分就是报错的位置,但实际错误的语句就是单引号括起来的前面一句的语句错误

下面是我写的自定义函数

##随机时间age
drop FUNCTION if exists getTime;

delimiter $$
create function getTime() 
returns TIMESTAMP
no sql
begin
	declare randNum int(2) default 0;
	declare returnTime TIMESTAMP;
	set randNum=floor(rand()*10);
	IF randNum<5 THEN
		set returnTime=date_add(curdate(),interval floor(1-(rand()*365))day);
	ELSE
		set returnTime=date_add(curdate(),interval floor(1+(rand()*365))day);
	END IF
	return returnTime;
end $$

报错显示最后一句'return returnTime; end',错误处:前一句END IF (未加分号结尾)

正确语法

##随机时间age
drop FUNCTION if exists getTime;

delimiter $$
create function getTime() 
returns TIMESTAMP
no sql
begin
	declare randNum int(2) default 0;
	declare returnTime TIMESTAMP;
	set randNum=floor(rand()*10);
	IF randNum<5 THEN
		set returnTime=date_add(curdate(),interval floor(1-(rand()*365))day);
	ELSE
		set returnTime=date_add(curdate(),interval floor(1+(rand()*365))day);
	END IF;
	return returnTime;
end $$

还有要注意的是,赋值的时候一定要加set,本人正是因为这个问题一直没发现,才在此深刻检讨

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

day day day ...

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值