我想在MySQL数据库中存储许多记录。它们都包含货币价值。但我不知道每个数字要插入多少位。 为此,我必须使用哪种数据类型? VARCHAR或INT(或其他数值数据类型)?
当前回答
如果要求符合GAAP,或者需要小数点后4位:
小数(13、4) 支持最大值为:
The $999999999999
否则,如果小数点后2位足够: 小数(13日2)
src: https://rietta.com/blog/best-data-types-for-currencymoney-in/
其他回答
实际上,这取决于程序员的偏好。我个人使用:数字(15,4)来符合公认会计原则(GAAP)。
因为货币需要精确的表示,所以不要使用像float这样的近似数据类型。您可以使用定点数值数据类型
decimal(15,2)
15是精度(包括小数点在内的值的总长度) 2是小数点后的位数
参见MySQL数值类型:
当需要保持精确的精确度时,例如货币数据,就会使用这些类型。
我更喜欢使用BIGINT,并通过与100相乘来存储值,这样它将成为整数。
例如,要表示93.49的货币值,该值应存储为9349,而显示的值可以除以100并显示。这将占用更少的存储空间。
警告: 大多数情况下,我们不执行货币*货币乘法,以防万一,如果我们正在执行,然后将结果除以100并存储,以便返回适当的精度。
乘以10000并存储为BIGINT,就像Visual Basic和Office中的“货币”一样。参见https://msdn.microsoft.com/en-us/library/office/gg264338.aspx
你可以使用DECIMAL或NUMERIC,两者都是一样的
DECIMAL和NUMERIC类型存储精确的数值数据值。当需要保持精确的精确度时,例如货币数据,就会使用这些类型。在MySQL中,NUMERIC被实现为DECIMAL,因此下面关于DECIMAL的说明同样适用于NUMERIC。: MySQL
例如十进制(10,2)
良好的阅读