当前位置:Gxlcms > 数据库问题 > SQL 保留两位小数的实现方式

SQL 保留两位小数的实现方式

时间:2021-07-01 10:21:17 帮助过:5人阅读

ROUND(123.9994, 3) --123.9990 SELECT ROUND(123.9995, 3) --124.0000 SELECT ROUND(748.584, -1) --750.000 SELECT ROUND(748.586, -2) --700.000 SELECT ROUND(748.586, -3) --Error 将expression转换为数据类型 numeric 时出现算术溢出错误 SELECT ROUND(748.586, -4) --0.000,如果length为负数,并且大于小数点前的数字个数,则ROUND将返回 0 SELECT ROUND(151.75, 0,0) --152.00 舍入 SELECT ROUND(151.75, 0,1) --151.00 截断

 

2、使用CONVERT()函数,使用示例:

  SELECT CONVERT(DECIMAL(13,2),13.123) --13.12 

3、使用CAST()函数,使用示例:

  SELECT CAST(13.123 as DECIMAL(13,2)) --13.12 

 

这三种方法(其实是两种),还是有区别的,区别在于ROUND()只是进行四舍五入,仍然会保留后面的位数为0,但是convert()和cast() 却会截断后面的位数,示例:

SELECT CONVERT(DECIMAL(13,2),13.123)    --13.12
SELECT CAST(13.123 as DECIMAL(13,2))    --13.12
SELECT ROUND(13.123,2)                  --13.120

 

根据需求这里采用第2种方案,但是仅这样处理还是不够的,返回的float型,经过代码处理后,仍然会舍去最后的"0"位。

 

最终的解决方案为:数据库查询时,把float型数据转换为字符型,再交由代码处理返回给客户端。

具体实现为:

 SELECT RTRIM(CONVERT(DECIMAL(13,2),13.123)) 

 

附RTRIM()的用法,返回删除了尾随空格的字符表达式。:

RTRIM(character expression)

示例:

SELECT RTRIM(Hello   )+%                    --Hello%
SELECT RTRIM(Hello)+%                       --Hello%
SELECT RTRIM(hello  + ‘‘ + world )+%      --helloworld%
SELECT RTRIM(hello  + ‘‘ + world )+%      --hello world%
SELECT RTRIM(hello +   + world )+%      --hello world%

 

SQL 保留两位小数的实现方式

标签:

人气教程排行