我想在MySQL数据库中存储许多记录。它们都包含货币价值。但我不知道每个数字要插入多少位。 为此,我必须使用哪种数据类型? VARCHAR或INT(或其他数值数据类型)?


当前回答

我更喜欢使用BIGINT,并通过与100相乘来存储值,这样它将成为整数。

例如,要表示93.49的货币值,该值应存储为9349,而显示的值可以除以100并显示。这将占用更少的存储空间。

警告: 大多数情况下,我们不执行货币*货币乘法,以防万一,如果我们正在执行,然后将结果除以100并存储,以便返回适当的精度。

其他回答

我们用double。

*喘息*

Why?

因为它可以表示任何15位的数字而不受小数点位置的限制。所有这些都只有可怜的8个字节!

所以它可以表示:

0.123456789012345 123456789012345.0

...以及介于两者之间的任何东西。

这很有用,因为我们处理的是全球货币,double可以存储我们可能遇到的小数点后的各种数字。

一个双字段可以代表日元的999,999,999,999,999,美元的99999,999,999.99,甚至比特币的99999,999.99999999

如果您尝试对decimal进行同样的操作,则需要decimal(30,15),它占用14个字节。

警告

当然,使用double也不是没有注意事项。

然而,这并不像一些人倾向于指出的那样失去准确性。尽管double本身在内部可能不精确到以10为基数的系统,但我们可以通过将从数据库中提取的值四舍五入到有效的小数点后数位来使其精确。如果需要的话。(例如,如果它将被输出,并且需要以10为基数的表示。)

需要注意的是,任何时候我们使用它进行算术运算时,我们都需要在以下情况下对结果进行归一化(通过四舍五入到有效的小数点位):

对其执行比较。 将其写入数据库。

另一种警告是,与decimal(m, d)不同的是,数据库将阻止程序插入多于m位的数字,而double则不存在这样的验证。一个程序可以插入一个用户输入的20位数字,它最终会被无声地记录为一个不准确的数量。

这取决于你的需要。

使用DECIMAL(10,2)通常就足够了,但如果你需要更精确的值,你可以设置DECIMAL(10,4)。

如果使用大值,则将10替换为19。

在提出这个问题的时候,没有人考虑比特币的价格。在BTC的情况下,使用DECIMAL(15,2)可能是不够的。如果比特币将上涨到10万美元或更多,我们将至少需要DECIMAL(18,9)来支持我们的应用程序中的加密货币。

DECIMAL(18,9)在MySQL中占用12个字节的空间(每9个数字占用4个字节)。

将钱存储为BIGINT乘以100或更多,以使用更少的存储空间为理由,在所有“正常”情况下都没有意义。

为了与GAAP保持一致,以DECIMAL(13,4)存储货币就足够了。 MySQL手册读到每9位需要4个字节来存储DECIMAL。 https://dev.mysql.com/doc/refman/8.0/en/precision-math-decimal-characteristics.html DECIMAL(13,4)表示9位+ 4位小数(小数点后数位)=> 4 + 2字节= 6字节 与存储BIGINT所需的8个字节相比。

实际上,这取决于程序员的偏好。我个人使用:数字(15,4)来符合公认会计原则(GAAP)。