结果
数据库的字段类型设置为decimal类型,但是小数位数为0,当我写入一个小于1的小数时候,则自动抹去,结果为0
起因
因为公司有一个业务需求,会对订单的收益进行分成,分成比例是10%,当订单金额为5.00元时,理论上分成应该为0.5元,但是查询数据库的值为零。
经过
怀疑是计算有问题,导致JAVA对象的字段没有值,插入数据库的时候使用的是数据库的默认值。所以排查JAVA代码,发现无异常,排查插入数据库时候的SQL语句,SQL语句一切正常,怀疑可能是BUG,上百度寻求答案,找到如下内容
https://ask.csdn.net/questions/257611
因为是架构师设计的表,因为充分的信任,没怀疑过数据库的设计问题。
经过排查,数据库的字段的小数位数确实设置为0,经过修改,一切恢复正常
记一笔,备忘。。。