JAVA BigDecimal数据写入Mysql不正确

JAVA BigDecimal数据写入Mysql不正确

结果

数据库的字段类型设置为decimal类型,但是小数位数为0,当我写入一个小于1的小数时候,则自动抹去,结果为0

起因

因为公司有一个业务需求,会对订单的收益进行分成,分成比例是10%,当订单金额为5.00元时,理论上分成应该为0.5元,但是查询数据库的值为零。

经过

怀疑是计算有问题,导致JAVA对象的字段没有值,插入数据库的时候使用的是数据库的默认值。所以排查JAVA代码,发现无异常,排查插入数据库时候的SQL语句,SQL语句一切正常,怀疑可能是BUG,上百度寻求答案,找到如下内容

https://ask.csdn.net/questions/257611

因为是架构师设计的表,因为充分的信任,没怀疑过数据库的设计问题。

经过排查,数据库的字段的小数位数确实设置为0,经过修改,一切恢复正常

记一笔,备忘。。。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值