MySQL中ROUND四舍五入函数需要注意的地方
类别:数据库 浏览量:450
时间:2017-3-5 MySQL中ROUND四舍五入函数需要注意的地方
MySQL中ROUND四舍五入函数需要注意的地方一、问题描述
1、有如下一个数据表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;
2、向这个表中插入一条数据
INSERT INTO test (field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5);
3、如果执行下面这个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;
4、执行后的结果
*************************** 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)
备注:最初一直以为这样的结果肯定是都是101,因为上面这六个取值结果都是对100 * 1.005进行四舍五入,结果肯定都是101才对,而后面两个肯定是4和3才对,但是最终的结果却是与设想的大相径庭
二、ROUND随机函数出现这种情况的原因
mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则
1、对于精确的数值,ROUND函数使用四舍五入
2、对于近似值,则依赖于底层的C函数库,在很多系统中ROUND函数会使用“取最近的偶数”的规则
3、通过这两条规则,我们可以看出,由于我们在使用两个字段相乘的时候,最终的结果是按照float类型处理的,而在计算机中float类型不是精确的数,因此处理结果会按照第二条来,而直接整数字段与1.005这样的小数运算的结果是因为两个参与运算的值都是精确数,因此按照第一条规则计算。
4、从field5和field6执行ROUND函数的结果可以明确的看确实是转换为了最近的偶数。
三、MySQL中ROUND备注
在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果有可能是不准确的。
标签:MySQL
您可能感兴趣
- mysql中group_concat
- mysql语句运行顺序(浅谈mysql执行过程以及顺序)
- mysqldecimal类型转换(mysql中decimal数据类型小数位填充问题详解)
- 所有聚合函数mysql教程(Mysql 聚合函数嵌套使用操作)
- mysql 分片键规则(MySql8 WITH RECURSIVE递归查询父子集的方法)
- mysql查看数据库cpu使用率(CPU 以及内存从哪些方面影响 MySQL 性能?)
- 对mysql索引的理解(详解MySQL 8.0 之不可见索引)
- mysql的常见优化(详解GaussDB for MySQL性能优化)
- mysql8.0.15官方最新版本安装教程(MySQL8.0.24版本Release Note的一些改进点)
- mysql的字符串截取函数(MySQL实现字符串的拼接,截取,替换,查找位置的操作)
- mysql缓存是什么(详解mysql查询缓存简单使用)
- 查看mysql索引缓存(MySQL查询缓存的小知识)
- linuxmysql安装教程5.7.25学习(linux mysql5.5升级至mysql5.7的步骤与踩到的坑)
- mysql判断表中字段是否存在(mysql插入前判断数据是否存在的操作)
- mysql锁类型大全(简单了解 MySQL 中相关的锁)
- MySQL SQL Assistant智能提示
- 大女主 汤唯垂青电视圈,搭档朱亚文出演《大明皇妃孙若微传》(汤唯垂青电视圈)
- 红色代表什么(红色代表什么情感和含义)
- 高中数学题(高中数学题型总结及解题方法)
- 冰岛旅游攻略(冰岛旅游攻略及花费)
- 为什么现在年轻人越来越喜欢买衣服(为什么现在年轻人越来越喜欢买衣服穿)
- 怎么做好SEO(怎么做好seo内容优化)
热门推荐
- markdown和python的关系(解决python Markdown模块乱码的问题)
- sql语句实现分页(SQL 窗口函数实现高效分页查询的案例分析)
- 有哪些最好用的云服务器(日本云服务器好不好?日本云服务器有哪些优势?)
- php批量导出所有数据库(php快速导入大量数据的实例方法)
- IIS7支持html中<!--#include --> 包含文件的方法
- iis服务器ftp设置(在云服务器上使用iis搭建一个ftp站点的方法图解)
- vps云服务怎么做(vps云主机的基础认识)
- dedecms怎么调用标签(DEDECMS 留言薄模块的使用方法)
- css动画的性能(你所不知道的 CSS 动画技巧与细节)
- layui导航栏(使用layui实现左侧菜单栏及动态操作tab项的方法)