- 问题场景:因数据库设置的decimal类型数据保留小数点位数过长。导致Java查询数据时,Bigdecimal类型的类字段去映射数据库decimal类型字段时会出现多余且无效的0,直接返回给前端时小数点后会出现多余的0,会造成前端处理非常的麻烦,例如返回前端结果如下
如果数据库中设置decimal精度大于6时,字段中存储的数据为0时返回到前端的数据就有可能会返回"0E-8" - 解决方案 :为自定义 CustomerBigDecimalSerialize
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.Objects;
public class CustomerBigDecimalSerialize extends JsonSerializer<BigDecimal> {
@Override
public void serialize(BigDecimal value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
if(Objects.nonNull(value)) {
//返回到前端的数据为数字类型,前端接收有可能丢失精度
//gen.writeNumber(value.stripTrailingZeros());
//返回到前端的数据为字符串类型
gen.writeString(value.stripTrailingZeros().toPlainString());
//去除0后缀,如果想统一进行保留精度,也可以采用类似处理
}else {//如果为null的话,就写null
gen.writeNull();
}
}
}
后再字段上加上注解
//在vo类字段中对字段加上@JsonSerialize注解
@JsonSerialize(using = CustomerBigDecimalSerialize.class)
private BigDecimal totalExchangeBtc; //抵扣电费的usdt兑换的btc总量
@JsonSerialize(using = CustomerBigDecimalSerialize.class)
private BigDecimal perTotalExchangeBtc; //兑换的btc总量对应每份的btc
@JsonSerialize(using = CustomerBigDecimalSerialize.class)
private BigDecimal exchangeUsdtPrice; //兑换时usdt的价格