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


当前回答

这取决于你的需要。

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

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

其他回答

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

因为货币需要精确的表示,所以不要使用像float这样的近似数据类型。您可以使用定点数值数据类型

decimal(15,2)

15是精度(包括小数点在内的值的总长度) 2是小数点后的位数

参见MySQL数值类型:

当需要保持精确的精确度时,例如货币数据,就会使用这些类型。

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

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

例如十进制(10,2)

良好的阅读

这取决于你的需要。

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

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

试着用

Decimal(19,4)

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