SQL 保留两位小数

一、 代码中处理,检测到为金额字段,做特殊处理;二、修改查询SQL语句去规避此问题; 第一种方法,无论通过数据类型还是字段名称,都不好判断是否为金额,故选用第二种方法。

SQL中保留两位小数的方法有三种,(第2、3种方法类似):

1、使用ROUND()函数,ROUND返回一个数值,舍入到指定的长度或精度,使用示例:

 

SELECT 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%
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值