我想在MySQL数据库中存储许多记录。它们都包含货币价值。但我不知道每个数字要插入多少位。 为此,我必须使用哪种数据类型? VARCHAR或INT(或其他数值数据类型)?
当前回答
如果您的应用程序需要处理高达万亿的货币值,那么这应该工作:13,2 如果你需要遵守GAAP(公认会计原则),那么使用:13,4
通常你应该把你的货币值加到13,4,然后把输出四舍五入到13,2。
其他回答
试着用
Decimal(19,4)
这通常适用于所有其他DB以及
我们用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位数字,它最终会被无声地记录为一个不准确的数量。
如果要求符合GAAP,或者需要小数点后4位:
小数(13、4) 支持最大值为:
The $999999999999
否则,如果小数点后2位足够: 小数(13日2)
src: https://rietta.com/blog/best-data-types-for-currencymoney-in/
因为货币需要精确的表示,所以不要使用像float这样的近似数据类型。您可以使用定点数值数据类型
decimal(15,2)
15是精度(包括小数点在内的值的总长度) 2是小数点后的位数
参见MySQL数值类型:
当需要保持精确的精确度时,例如货币数据,就会使用这些类型。
你可以使用DECIMAL或NUMERIC,两者都是一样的
DECIMAL和NUMERIC类型存储精确的数值数据值。当需要保持精确的精确度时,例如货币数据,就会使用这些类型。在MySQL中,NUMERIC被实现为DECIMAL,因此下面关于DECIMAL的说明同样适用于NUMERIC。: MySQL
例如十进制(10,2)
良好的阅读
推荐文章
- MySql: Tinyint (2) vs Tinyint(1) -有什么不同?
- 如何在MySQL表中移动列?
- 在MySQL中选择最后一行
- 如何删除MySQL root密码
- MySQL对重复键更新在一个查询中插入多行
- mysql_connect():[2002]没有这样的文件或目录(试图通过unix:///tmp/mysql.sock连接)在
- MySQL:如何复制行,但改变几个字段?
- 不能删除或更新父行:外键约束失败
- Mysql错误1452:不能添加或更新子行:外键约束失败
- MySQL DISTINCT在GROUP_CONCAT()上
- 第一次设计数据库:我是否过度设计了?
- MySQL选择一个列DISTINCT,与其他列相对应
- 错误1022 -不能写;表中重复的键
- 如何修改列和更改默认值?
- 如何在MySQL 8.0中授予root用户所有权限