1、我们在使用 BigDecimal 时,为了防止精度丢失,推荐使用它的BigDecimal(String val)构造方法或者 BigDecimal.valueOf(double val) 静态方法来创建对象。但是对于float,BigDecimal.valueOf方法则仍然会导致丢失精度,原因是float转double丢失了精度,因此需要将float转成String后转成BigDecimal。
2、某个对象里的字段类型是bigdecimal,值386.386,mysql对应decimal(10,2),最后mysql给我四舍五入386.39了,但是我想要的是386.38,我们可以通过setScale()方法来手动保留两位小数。
参考文章: