CREATE FUNCTION cleanAmount(amount DECIMAL)
    RETURNS decimal(30,2)
    LANGUAGE SQL
    DETERMINISTIC
    NO SQL
    SQL SECURITY DEFINER
    COMMENT ''
BEGIN
DECLARE res DECIMAL;
SET res=CAST(COALESCE(amount,0.00) AS DECIMAL(30,2));
RETURN res;
END

SELECT cleanAmount('3.456'); return 3,00. It should be 3,46

有帮助吗?

解决方案

Change the declare of res in the stored proc:-

CREATE FUNCTION cleanAmount(amount DECIMAL(60,30))
    RETURNS decimal(30,2)
    LANGUAGE SQL
    DETERMINISTIC
    NO SQL
    SQL SECURITY DEFINER
    COMMENT ''
BEGIN
DECLARE res DECIMAL(30,2);
SET res=CAST(COALESCE(amount,0.00) AS DECIMAL(30,2));
RETURN res;
END

其他提示

default decimal is probably rounding your number

DECLARE res DECIMAL(30,2)

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top