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

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


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

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

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


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

声明:本站所有文章和图片,如无特殊说明,均为原创发布。商业转载请联系作者获得授权,非商业转载请注明出处。
随机推荐
JavaScript 数据类型和变量
MySQL 批量修改时间
JavaScript BOM 浏览器对象模型
Debian11 安装笔记1:编译安装Nginx、Naxsi 和 Njs
JavaScript 滚动浏览器窗口到指定的元素
JavaScript DOM 元素增删改
WordPress 中如何在主题和插件中使用
JavaScript 事件流