MySQL 数据库中货币单位如何存储

阿里巴巴 Java 编程规范,【强制】任何货币金额,均以最小货币单位且为整型类型进行存储。


为什么要这样做呢,因为常常出现数据库里的数据获取后,直接返回给前端的。

因为在数据传输过程中使用的是2进制,数据在进制转换时会丢失精度。

浮点数使用JSON等格式传输数据时,会被转为二进制,二进制下很多浮点数是无限小数,而传输数据时候又不可能把无限制的传输这个数,只能把它截断,当浮点数被截断后,再转回十进制,就不是一个精确值了,所以就会出现接口返回{"a":0.3},但是调用接口实际获得{"a":0.30000000000000004}的问题。


参考:https://javascript.net.cn/articles/984

声明:本站所有文章和图片,如无特殊说明,均为原创发布。商业转载请联系作者获得授权,非商业转载请注明出处。
真诚赞赏,手留余香
赞赏
随机推荐
MySQL 字符串截取函数 SUBSTRING_INDEX
WordPress 添加 Favicon 图标的方法
WordPress 自定义 JWT 授权和验证
Git 放弃本地修改,强制和之前的某次提交同步
BoarAPI 框架
JavaScript 和 CSS 检测横屏适配
Linux netstat 命令
视频剪辑软件 Shotcut 笔记