mysql - float 和十进制数据类型之间的区别

标签 mysql

当我在 MySQL 中使用 float 和 decimal 数据类型有什么不同?

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

最佳答案

This是我有这个疑问时发现的。

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 部分。

所以对于总和,小数更好,但对于除法, float 是 更好,在某种程度上,当然。我的意思是,使用 DECIMAL 不会给出 无论如何,您都是“防故障算术”。

希望这会有所帮助。

关于mysql - float 和十进制数据类型之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5150274/

相关文章:

Mysql查询某个字段中的组数据

mysql - 无法弄清楚从多个表中提取数据的命令

python - 根据数据库正确验证 HTML POST

c# - 将 C# 数据传递到 MySQL

mysql - MySQL死锁: engine.日志分析

php - Codeigniter:获取相同值之间的公共(public)列值

mysql - 如何将一个单元格的总和放在另一个表mysql工作台的一个单元格中

java - Android - 将登录信息发送到 MySQL 数据库

mysql - 如何使用 CakePHP 将 SQL 查询记录到日志文件

mysql - mysql查询结果相减