没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
在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 f
资源推荐
资源详情
资源评论
MySQL之之ROUND函数四舍五入的陷阱函数四舍五入的陷阱
在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??。
weixin_38724535
- 粉丝: 3
- 资源: 915
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
- 3
前往页