3

我在 MySQL 中有一个存储函数:

CREATE FUNCTION `login_count`(o INT, start_date DATE, end_date DATE) RETURNS INT
READS SQL DATA
BEGIN
DECLARE total_count INT;
SELECT COUNT(*) INTO total_count FROM logins as l WHERE `order_id` = o && modified BETWEEN start_date AND end_date; 
RETURN total_count; 
END

非常基本,需要一个 id、开始日期和结束日期,并返回该日期范围内的登录次数。每当我运行它时,我都会返回 0。除非我删除了 where 子句的日期部分。然后它返回一个实际数字。或者,如果我只是手动将日期放入存储的函数中,它就可以工作......所以这不是日期的问题,但只有当我通过参数列表提供日期时它才会不喜欢它。

有什么想法会导致这种情况发生吗?我可以手动将日期放入存储的函数中这一事实确实让我感到烦恼。这里并没有发生很多事情可能会搞砸,所以我有点迷失了下一步该尝试什么。

此外,有没有办法调试存储的函数/过程。我只是得到一个 0 回来,但是有没有办法让我调试它来尝试找出可能发生的事情?

4

1 回答 1

2

我的第一个猜测是您提供的日期格式是 MySQL 无法识别的。MySQL 对日期文字的格式非常挑剔。它需要 YYYY-MM-DD、YY-MM-DD、YYYYMMDD 或 YYMMDD(您也可以使用任何其他标点符号代替破折号)。有关详细信息,请参阅DATETIME、DATE 和 TIMESTAMP 类型

您还可以使用STR_TO_DATE()函数将更多日期格式转换为 MySQL 接受的格式。

关于调试存储过程和存储函数,总是可以设置一个带@前缀的自定义变量,这个变量在存储函数返回后全局可用。像副作用一样。因此,您可以在运行存储的函数时使用它来设置诊断信息,然后再进行检查。

于 2009-08-05T21:53:03.347 回答