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

相关文章

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa