这个自定义函数为什么报错?

DELIMITER $$
CREATE DEFINER=`root`@`127.0.0.1` FUNCTION `test`(`depth` TINYINT, `nums` VARCHAR(1024)) RETURNS float(5,3)
    NO SQL
BEGIN
DECLARE rateStr char(8);
SET rateStr = substring_index(nums,',',depth);
RETURN CONVERT(rateStr, decimal(5,3)) / 100;
END$$
DELIMITER ;

在10.1.21-MariaDB上可以成功执行,在mysql 5.6.38上就不行

SELECT test(1,'100')

报如下错误:
Out of range value for column '(null)' at row 1

阅读 1.3k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏