使用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%总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java数据库连接池之DBCP浅析_动力节点Java学院整理
这篇文章主要为大家详细介绍了Java数据库连接池之DBCP的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-08-08
IntelliJ IDEA创建普通的Java 项目及创建 Java 文件并运行的教程
这篇文章主要介绍了IntelliJ IDEA创建普通的Java 项目及创建 Java 文件并运行的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02


最新评论