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 舍⼊
transform和convert的区别
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%