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