时间:2021-07-01 10:21:17 帮助过:5人阅读
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 保留两位小数的实现方式
标签: