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


当前回答

有2个有效选项:

使用整数数量的货币小单位(例如分) 将金额表示为货币的十进制值

在这两种情况下,您都应该使用十进制数据类型来拥有足够的有效数字。区别在于精度:

即使是整数数量的小单位,也最好有额外的累加精度(考虑从1美分操作累积10%的费用) 不同的货币有不同数量的小数,加密货币有多达18个小数 由于通货膨胀,小数的数量可以随着时间的推移而改变

来源和更多的警告和事实。

其他回答

试着用

Decimal(19,4)

这通常适用于所有其他DB以及

乘以10000并存储为BIGINT,就像Visual Basic和Office中的“货币”一样。参见https://msdn.microsoft.com/en-us/library/office/gg264338.aspx

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

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

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

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

有2个有效选项:

使用整数数量的货币小单位(例如分) 将金额表示为货币的十进制值

在这两种情况下,您都应该使用十进制数据类型来拥有足够的有效数字。区别在于精度:

即使是整数数量的小单位,也最好有额外的累加精度(考虑从1美分操作累积10%的费用) 不同的货币有不同数量的小数,加密货币有多达18个小数 由于通货膨胀,小数的数量可以随着时间的推移而改变

来源和更多的警告和事实。