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


当前回答

试着用

Decimal(19,4)

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

其他回答

这取决于你的需要。

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

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

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

将钱存储为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个字节相比。

如果要求符合GAAP,或者需要小数点后4位:

小数(13、4) 支持最大值为:

The $999999999999

否则,如果小数点后2位足够: 小数(13日2)

src: https://rietta.com/blog/best-data-types-for-currencymoney-in/

你可以使用DECIMAL或NUMERIC,两者都是一样的

DECIMAL和NUMERIC类型存储精确的数值数据值。当需要保持精确的精确度时,例如货币数据,就会使用这些类型。在MySQL中,NUMERIC被实现为DECIMAL,因此下面关于DECIMAL的说明同样适用于NUMERIC。: MySQL

例如十进制(10,2)

良好的阅读