MySQL TRUNCATE 或 ROUND 可变十进制长度 [英] MySQL TRUNCATE or ROUND with variable decimal length

查看:66
本文介绍了MySQL TRUNCATE 或 ROUND 可变十进制长度的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我无法在可变十进制长度上截断(或舍入)小数.这是我的 MySQL 查询:

I am not able to TRUNCATE (or round) a decimal on variable decimal lengh. Here's my MySQL query:

SELECT
TRUNCATE( `amount` , `decimal_length` ) AS truncated_decimal,
FROM table

-- sample data
amount    decimal length
123.123    0
456.456    1
789.789    2

--expected outcome
truncated_decimal
123
456.4
789.78

--current outcome (wrong)
truncated_decimal
123.123
456.456
789.789

我的 truncated_decimal 变量返回没有截断,即表中的默认十进制长度.与 ROUND 函数的行为相同.变量 decimal_length 是一个整数,对于表中的不同行不同.

My truncated_decimal variable is returned WITHOUT truncation, i.e. default decimal length from table. Same behavior with ROUND function. Variable decimal_length is an integer that is different for different rows in table.

有什么想法吗?

推荐答案

所以获得可变长度小数的正确答案是使用 FORMAT 函数:

So the correct answer to get variable length decimals is to use FORMAT function:

SELECT
FORMAT( `amount` , `decimal_length` ) AS truncated_decimal,
FROM table

它确实需要四舍五入,但至少您需要可变长度小数.

It does go with rounding, but at least you get needed variable length decimals.

这篇关于MySQL TRUNCATE 或 ROUND 可变十进制长度的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆