mysql之sql查询结果集小数保留
客户要求,跟金额相关的数据,打印出来要保留两位小数,比如:13.2/13.200要显示为13.20;
分析:
首先查看数据库中的数据定义,均为decimal(12,2) ,直接通过数据库查询的结果也会保留两位小数,但是代码处理后,却会忽略掉最后一个“零”位。
此处有两个解决方案:
一、 代码中处理,检测到为金额字段,做特殊处理;二、修改查询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
注:必须保证显示的位数,大于保留的小数位数,不然会出错。
数据最好采用varchar类型存储。
不建议使用convert.
根据需求这里采用第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%
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?