mysql格式化小数保留小数点后两位(小数点格式化)

Posted 坠落鱼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql格式化小数保留小数点后两位(小数点格式化)相关的知识,希望对你有一定的参考价值。

格式化浮点数的问题,用format(col,2)保留两位小数点,出现一个问题,例如下面的语句,后面我们给出解决方法

SELECT FORMAT(12562.6655,2);

 结果:12,562.67

查看文档:Formats the number X to a format like ‘#,###,###.##‘, rounded to D decimal places, and returns the result as a string. If D is 0, the result has no decimal point or fractional part.整数部分超过三位的时候以逗号分割,并且返回的结果是string类型的。

mysql> SELECT FORMAT(12332.123456, 4);
-> ‘12,332.1235‘
mysql> SELECT FORMAT(12332.1,4);
-> ‘12,332.1000‘
mysql> SELECT FORMAT(12332.2,0);
-> ‘12,332‘
没有达到预期结果,想要的结果不要以逗号分隔,
select truncate(4545.1366,2);

 结果:4545.13,直接截取不四舍五入,还是有问题。

select convert(4545.1366,decimal);

结果:4545.14,达到预期。

补充说明:convert不能四舍五入达到消息,convert的作用和truncate一样,截取小数点后两位。

四舍五入保留小数点后两位:ROUND(X,D)

 

select ROUND(4545.1366,2);

 

结果:4545.15,达到预期。

 

以上是关于mysql格式化小数保留小数点后两位(小数点格式化)的主要内容,如果未能解决你的问题,请参考以下文章

delphi 保留两位小数

shell保留两位小数,急求

Oracle小数点的实际保留问题的4方案

vb保留小数点后2位怎么编写?

Java实现小数点后保留两位

JS对数字进行货币格式化并且保留两位小数点,小数用0补全