在MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误。

问题描述

假如我们有如下一个数据表test,建表语句如下

CREATE TABLE test (

id int(11) NOT NULL AUTO_INCREMENT,

field1 bigint(10) DEFAULT NULL,

field2 decimal(10,0) DEFAULT NULL,

field3 int(10) DEFAULT NULL,

field4 float(15,4) DEFAULT NULL,

field5 float(15,4) DEFAULT NULL,

field6 float(15,4) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

我们创建了一个名为test的表,出了id字段之外还包含了多个字段,拥有这不同的数据类型。我们向这个表中插入一条数据

INSERT INTO test (field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5);

插入之后表中的数据是这样的

mysql> select * from test;

+----+--------+--------+--------+--------+--------+--------+

| id | field1 | field2 | field3 | field4 | field5 | field6 |

+----+--------+--------+--------+--------+--------+--------+

| 1 | 100 | 100 | 100 | 1.0050 | 3.5000 | 2.5000 |

+----+--------+--------+--------+--------+--------+--------+

1 row in set (0.00 sec)

如果现在我们执行下面这个SQL,你觉得结果会是什么样的呢?

SELECT

round(field1 * field4),

round(field2 * field4),

round(field3 * field4),

round(field1 * 1.005),

round(field2 * 1.005),

round(field3 * 1.005),

round(field5),

round(field6)

FROM test;

最初一直以为这样的结果肯定是都是101,因为上面这六个取值结果都是对100 * 1.005进行四舍五入,结果肯定都是101才对,而后面两个肯定是4和3才对,但是最终的结果却是与设想的大相径庭

*************************** 1. row ***************************

round(field1 * field4): 100

round(field2 * field4): 100

round(field3 * field4): 100

round(field1 * 1.005): 101

round(field2 * 1.005): 101

round(field3 * 1.005): 101

round(field5): 4

round(field6): 2

1 row in set (0.00 sec)

为什么会这样?

同样是100*1.005,为什么从数据库中的字段相乘得到的结果和直接字段与小数相乘得到的不一样呢?

对这个问题百思不得其解,各种百度谷歌无果。。。没办法,还得靠自己,这个时候最有用的就是官网文档了,于是查询了mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则

For exact-value numbers, ROUND() uses the “round half up” rule(对于精确的数值,ROUND函数使用四舍五入)

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类型处理的,而在计算机中float类型不是精确的数,因此处理结果会按照第二条来,而直接整数字段与1.005这样的小数运算的结果是因为两个参与运算的值都是精确数,因此按照第一条规则计算。从field5和field6执行ROUND函数的结果可以明确的看确实是转换为了最近的偶数。

总结

从这个例子中可以看到,在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果是不准确的。

本文将会持续修正和更新,最新内容请参考我的 GITHUB 上的 程序猿成长计划 项目,欢迎 Star,另外,求follow?。

mysql decimal被四舍五入_MySQL之ROUND函数四舍五入的陷阱相关推荐

  1. mysql round 四舍五入_MySQL之ROUND函数四舍五入的陷阱

    [TOC] 在MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误. 问题描述 假 ...

  2. mysql round不四舍五入_MySQL中ROUND函数进行四舍五入操作陷阱分析

    本文实例讲述了MySQL中ROUND函数进行四舍五入操作陷阱.,具体如下: 在MySQL中, ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本 ...

  3. MySQL : ROUND 函数四舍五入陷阱及解决办法

    在MySQL中, ROUND 函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并无预期的那样,本文将这一问题记录下来,并提出解决方案. 问题描述 假如咱们有以下一个数据表 ...

  4. MySQL 之 ROUND 函数四舍五入的陷阱

    在MySQL中, ROUND 函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误. 问题描述 假如我们有 ...

  5. excel取整函数_excel舍入函数应用视频:int取整函数技巧round函数四舍五入保留指定小数位...

    excel舍入函数应用视频:int取整函数技巧视频-round函数四舍五入视频-excel保留指定小数位视频 本视频教程由部落窝教育分享.更多Excel教程请到QQ群:514869990. https ...

  6. Oracle round 函数(四舍五入)

    如何使用 Oracle Round 函数 (四舍五入) 描述 : 传回一个数值,该数值是按照指定的小数位元数进行四舍五入运算的结果. SELECT ROUND( number, [ decimal_p ...

  7. 四舍五入函数 oracle,Oracle round函数 四舍五入

    Oracle Round 函数 (四舍五入) 描述 : 传回一个数值,该数值是按照指定的小数位元数进行四舍五入运算的结果. SELECT ROUND( number, [ decimal_places ...

  8. mysql内置含糊_mysql内置函数

    1 字符串函数 查看字符串的ascii码: ascii(str) str为空时候返回0 select ascii("a"); 查看ascii码对应的字符: char(num) se ...

  9. Math.Round函数四舍五入的问题

    今天客户跑过来跟我说,我们程序里面计算的价格不对,我检查了一下,发现价格是经过折算后的价格,结果是可能小数位较多,而单据上只能打印两位价格,所以就对价格调用Math.Round(price,2)函数进 ...

最新文章

  1. Spring框架中的设计模式(一)
  2. Java之JSON数据
  3. 小议如何跳出魔改网络结构的火坑
  4. 充分利用 UE4 中的噪声
  5. Linux系统查看华为存储型号,linux 查看服务器存储
  6. 手动安装vue-devtools
  7. 微信小游戏跳坑之旅(一)——使用白鹭引擎开发之创建项目
  8. 利用CURL修改页面内容
  9. ubuntu环境下安装opencv教程及测试
  10. PC蓝牙加串口调试助手调试蓝牙设备
  11. Linux tar打包命令详解
  12. IDEA中阿里p3c代码规范
  13. PID控制最通俗的解释与PID参数的整定方法
  14. Excel快捷键大全 Excel常用快捷键大全
  15. 地下城与勇士(DNF)安图恩副本(黑雾之源、震颤的大地、舰炮防御战、擎天之柱、能量阻截战、黑色火山、安徒恩的心脏)(童年的回忆)
  16. 单点登录SSO----JSON Web Token(JWT)机制
  17. javascript event click/dblclick left/right区分左键、右键、双击事件,排除点击事件与拖拽事件冲突,做防抖优化
  18. 每日单词20110603
  19. 有了方差为什么需要标准差?
  20. 适用于产研团队协作工具有哪些?盘点6大类协同办公软件

热门文章

  1. 孤岛生存java_我的世界:一座孤岛等于拥有“全部”,这个孤岛种子非常适合生存...
  2. 移动端上下拖动调整顺序效果_HTML5 移动端的上下左右滑动问题
  3. python 单反格式转格式_如何用单反斜杠转义字符串的特殊字符 - python
  4. Swagger启动报错Failed to start bean ‘documentationPluginsBootstrapper‘
  5. 洛谷——P1035 [NOIP2002 普及组] 级数求和
  6. 【CF311E】biologist
  7. [RK3288][Android6.0] 系统按键驱动流程分析【转】
  8. F1-VmwareCentOS7.x
  9. 华为交换机vlan划分常用命令
  10. SQL Server对Xml字段的操作