MySQL 浮点数字段“四舍五入”问题

2024-05-01 09:08

本文主要是介绍MySQL 浮点数字段“四舍五入”问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL 浮点数字段 “四舍五入”查询时,数据计算错误问题

1、MySQL “四舍五入” 运算函数
通常,我们在进行MySQL数据“四舍五入”查询时,会用到 ROUND(x,y)函数 ,在直接使用时,其数据结果显示正常,如下所示:

SELECT ROUND(3.14,1),ROUND(3.15,1) FROM dual;

执行结果如下:

ROUND(3.14,1)ROUND(3.15,1)
3.13.2

2、MySQL 浮点数字段小数“四舍五入”问题演示
首先,创建一个含有 float和double类型的两个浮点数字段和一个decimal类型的小数字段

CREATE TABLE `demo` (`id` int(11) NOT NULL AUTO_INCREMENT,`float_column` FLOAT,`double_column` DOUBLE,`decimal_column` DECIMAL(5,2),PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8 COLLATE=utf8_bin;

然后,写入特定临界点数据

insert into demo values 
(null,3.24,3.24,3.24),
(null,3.25,3.25,3.25);

最后,执行查询脚本

SELECT float_column,ROUND(float_column,1), double_column,ROUND(double_column,1),decimal_column,ROUND(decimal_column,1) FROM demo;

执行结果如下表所示:

float_columnROUND(float_column,1)double_columnROUND(double_column,1)decimal_columnROUND(decimal_column,1)
3.243.23.243.23.243.2
3.253.23.253.23.253.3

从查询结果中可以看出,float_column 和 double_column 使用 ROUND() 函数“四舍五入”后的结果 是 错误

那么这个问题的原因出在哪里呢?
我们查看MySQL的官方文档,发现关于 ROUND()函数有如下两条规则

  1. For exact-value numbers, ROUND() uses the “round half up”
    rule.
    对于精确的数值, ROUND 函数使用四舍五入
  2. For approximate-value numbers, the
    result depends on the C library. On many systems, this means that
    ROUND() uses the “round to nearest even” rule: A value with any
    fractional part is rounded to the nearest even integer.
    对于近似值,则依赖于底层的C函数库,在很多系统中 ROUND 函数会使用“取最近的偶数”的规则

由此可见:在float和double两个浮点数字段中存储的 3.25ROUND(X,1) 函数运算时,符合第二条规则,故返回了 最近偶数3.2

3、解决方案
方案一:可以在设计表结构的时候,对此类需要四舍五入的数值字段,设置为 DECIMAL 类型。
方案二:通过CAST()函数,将浮点型字段,转换为 DECIMAL格式,再进行ROUND 函数处理 。当需要处理的仅为单个表字段时,直接使用CAST()函数即可完成“浮点数”转换为“小数” 及 “四舍五入”计算
示例如下:

SELECT float_column,ROUND(float_column,1),ROUND(CAST(float_column AS decimal(3,2)),1), CAST(float_column AS decimal(3,1)) FROM demo;

查询结果:

float_columnROUND(float_column,1)ROUND(CAST(float_column AS decimal(3,2)),1)CAST(float_column AS decimal(3,1))
3.243.23.23.2
3.253.23.33.3

这篇关于MySQL 浮点数字段“四舍五入”问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/951281

相关文章

MySQL 多表连接操作方法(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN)

《MySQL多表连接操作方法(INNERJOIN、LEFTJOIN、RIGHTJOIN、FULLOUTERJOIN)》多表连接是一种将两个或多个表中的数据组合在一起的SQL操作,通过连接,... 目录一、 什么是多表连接?二、 mysql 支持的连接类型三、 多表连接的语法四、实战示例 数据准备五、连接的性

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图