您好,欢迎来到华佗小知识。
搜索
您的当前位置:首页SQL保留两位小数的实现方式

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

来源:华佗小知识
SQL保留两位⼩数的实现⽅式

问题:

  客户要求,跟⾦额相关的数据,打印出来要保留两位⼩数,⽐如:13.2/13.200要显⽰为13.20; 分析:

⾸先查看数据库中的数据定义,均为decimal(12,2) ,直接通过数据库查询的结果也会保留两位⼩数,但是代码处理后,却会忽略掉最后⼀个“零”位。

此处有两个解决⽅案:

  ⼀、 代码中处理,检测到为⾦额字段,做特殊处理;⼆、修改查询SQL语句去规避此问题; 第⼀种⽅法,⽆论通过数据类型还是字段名称,都不好判断是否为⾦额,故选⽤第⼆种⽅法。SQL中保留两位⼩数的⽅法有三种,(第2、3种⽅法类似):

1、使⽤ROUND()函数,ROUND返回⼀个数值,舍⼊到指定的长度或精度,使⽤⽰例:

SELECT ROUND(123.9994, 3) --123.9990SELECT ROUND(123.9995, 3) --124.0000SELECT ROUND(748.584, -1) --750.000SELECT ROUND(748.586, -2) --700.000

SELECT ROUND(748.586, -3) --Error 将expression转换为数据类型 numeric 时出现算术溢出错误

SELECT ROUND(748.586, -4) --0.000,如果length为负数,并且⼤于⼩数点前的数字个数,则ROUND将返回 0SELECT 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.12SELECT CAST(13.123 as DECIMAL(13,2)) --13.12SELECT 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%

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- huatuo0.cn 版权所有 湘ICP备2023017654号-2

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务