首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

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

MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误。...field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5); 插入之后表中的数据是这样的 mysql...没办法,还得靠自己,这个时候最有用的就是官网文档了,于是查询了mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则 For exact-value numbers, ROUND() uses...the “round half up” rule(对于精确的数值,ROUND函数使用四舍五入) For approximate-value numbers, the result depends on...总结 从这个例子中可以看到,在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果是不准确的。

79620

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

[FullSizeRender 2] TOC 在MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误...field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5); 插入之后表中的数据是这样的 mysql...没办法,还得靠自己,这个时候最有用的就是官网文档了,于是查询了mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则 For exact-value numbers, ROUND() uses...the “round half up” rule(对于精确的数值,ROUND函数使用四舍五入) For approximate-value numbers, the result depends on...总结 从这个例子中可以看到,在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果是不准确的。

1.7K40

MySQL对小数进行四舍五入等操作

数学函数是MySQL中常用的一类函数。其主要用于处理数字,包括整型和浮点数等等。 MySQL常用的四舍五入函数: 函数说明 FLOOR(X) 返回不大于X的最大整数。...ROUND(X) 返回离X最近的整数,截断时要进行四舍五入。 ROUND(X,D) 保留X小数点后D位的值,截断时要进行四舍五入。...TRUNCATE(X,D) 返回数值X保留到小数点后D位的值,截断时不进行四舍五入。 FORMAT(X,D) 将数字X格式化,将X保留到小数点后D位,截断时要进行四舍五入。...SELECT CEIL(1.3); -- 输出结果:2 SELECT CEILING(1.8); -- 输出结果:2 4、ROUND(X)函数 返回离X最近的整数,截断时要进行四舍五入。...SELECT TRUNCATE(1.2328,3); -- 输出结果:1.232 6、FORMAT(X,D)函数 将数字X格式化,将X保留到小数点后D位,截断时要进行四舍五入

35530

php四舍五入

小数例子: PHP保留两位小数并且四舍五入 1 $n=0.1265489; 2 echo sprintf("%.2f", $n); // 0.13 大家可以看到我们用到了sprintf函数对$n进行了格式化...%.2f是目标格式,其中2表示两位f表示float(浮点型) 第3为小数6被四舍五入 再看个例子 1 $n=0.1265489 2 echo substr(sprintf("%.3f",$n),0,-...1);// 0.12 代码输出了保留2为小数没有四舍五入,实际上我们了解了sprintf的特性会四舍五入小数后我们多保留了一位,然后用substr来截取前2位 取整例子: 1 echo ceil(4.1...round 的参数一是数据源,参数二是要保留的小数位而且之后一位(比如你输入2那么第3为是之后一位)被四舍五入,当他是负数的时候,从数据源最后一位开始往前数相应的长度制0并将最后一位四舍五入比如round...(123456,-2) 就是123456从6开始往前数两位都变成零,并且最后一位5(从后往前数第一位是6最后一位是5)被四舍五入,输出123500

2K40

Python 四舍五入

在进行数字剪裁操作时,四舍五入事实上有多种方式,本文记录相关内容以及 Python 实现。 四舍五入 本是很简单的道理,在实际使用过程中发现有些细节上的不同。...标准的四舍五入 舍入到整数: 如果小数部分小于0.5,则舍去小数部分,保留整数部分。 如果小数部分大于或等于0.5,则将整数部分加1。 例如: 3.2 四舍五入到整数是 3。...例如: 3.141592653589 四舍五入到两位小数是 3.14。 3.141592653589 四舍五入到三位小数是 3.142。...decimal.ROUND_HALF_UP:四舍五入,5进位。 decimal.ROUND_HALF_DOWN:四舍五入,5舍去。...decimal.ROUND_HALF_EVEN:四舍五入,5向最近的偶数舍入。 但是我在一次实验中还是发现了不正确的四舍五入,暂时没有复现,使用的时候还是要多加小心。

8910

java中的四舍五入函数_java中进行四舍五入

在oracle中有一个很好的函数进行四舍五入,round(), select round(111112.23248987,6) from dual; 但是java的Number本身不提供四舍五入的方法,...在java中可以使用java.math.BigDecimal来进行四舍五入,或者直接使用DecimalFormat来控制小数位数的精度来进行四舍五入。...=dfc.format(resultVar); System.out.println(” cellContent “+cellContent); 在使用中,有时候会动态保留小数的位数,甚至银行家算法中四舍五入并不完全是...直接删除多余的小数位,如2.35会变成2.3 setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4 setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入...,2.35变成2.4 setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍 关于new BigDecimal( double value

1.1K20

不做软件测试,你养我啊?

这是来自喜剧之王周星驰和张柏芝的经典对话,换到现在的软件测试行业,我不做软件测试,你养我啊?这句话是自己的内心独白还是希望有个依靠呢?我们把“我不做软件测试,你养我啊”当做一个需求来拆解下测试用例。...首先是我不做软件测试(后面内容不变),这句话,就是我如果做软件测试,不做软件测试,做了软件测试以后不做软件测试,三种情况来先分析下。...千万不要心浮气躁,换来换去,也许会让你处境更糟糕; 第二种情况,不做软件测试,场景很多,我说下就比较贴合现状,我不喜欢测试,但大家认为测试目前我求职或者工作的最好方向,如毕业或者年纪大了,转行,这种表现的就是自己的迷茫和无奈...,对于刚毕业生,就业竞争压力大,专业不对口,是先就业还是择业,基本都是赶紧先就业,这是想说我不做测试,其实就是想挣扎下,找到自己兴趣的行业,去选择,希望自己的父母能自己多一点时间,让自己有选择的权利。

13710
领券