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

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


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

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

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


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

声明:本站所有文章和图片,如无特殊说明,均为原创发布。商业转载请联系作者获得授权,非商业转载请注明出处。
真诚赞赏,手留余香
赞赏
随机推荐
Debian11 安装笔记4:安装常用软件
RESTful API 执行 delete 返回204无法获取 Body
Node.js 18.x 开始支持内置单元测试
Land 主题
Nginx 使用 Njs 授权访问文件
WordPress 常用接口
WordPress 使用 shortcode() 增加编辑器功能
Node.js 使用 Jest 做单元测试