浮点和十进制数据类型之间的区别 [英] Difference between float and decimal data type

查看:102
本文介绍了浮点和十进制数据类型之间的区别的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我在MySQL中使用浮点和十进制数据类型时,有什么区别?

What difference does it make when I use float and decimal data types in MySQL?.

我什么时候应该使用哪个?

When should I use which?

推荐答案

是我在发现这个东西时发现的怀疑.

This is what I found when I had this doubt.

mysql> create table numbers (a decimal(10,2), b float);
mysql> insert into numbers values (100, 100);
mysql> select @a := (a/3), @b := (b/3), @a * 3, @b * 3 from numbers \G
*************************** 1. row ***************************
  @a := (a/3): 33.333333333
  @b := (b/3): 33.333333333333
@a + @a + @a: 99.999999999000000000000000000000
@b + @b + @b: 100

在这种情况下,小数确实做了应该做的事情,它 截短其余部分,从而丢失了1/3的部分.

The decimal did exactly what's supposed to do on this cases, it truncated the rest, thus losing the 1/3 part.

所以对于总和,小数点更好,但是对于除法,浮点数是 当然,在某种程度上更好.我的意思是,使用DECIMAL不会给 可以说是您的防故障算法".

So for sums the decimal is better, but for divisions the float is better, up to some point, of course. I mean, using DECIMAL will not give you a "fail proof arithmetic" in any means.

希望这会有所帮助.

这篇关于浮点和十进制数据类型之间的区别的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆