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

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


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

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

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


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

声明:本站所有文章和图片,如无特殊说明,均为原创发布。商业转载请联系作者获得授权,非商业转载请注明出处。
随机推荐
MySQL 的 sql_mode 模式介绍:为什么 MySQL 中 int,float,double 类型字段插入空字符时自动转为0
Debian11 安装笔记4:安装常用软件
JavaScript 的历史
MySQL 使用 DATE_FORMAT() 和 FROM_UNIXTIME() 格式化时间
WordPress 函数 get_categories() 获取所有分类
WordPress 插件开发
Linux apt 命令
JavaScript URL 对象