当前位置:首页 » 《关注互联网》 » 正文

Java返回前端Bigdecimal类型数据时“0E-8“及小数点多余0的问题

16 人参与  2024年10月01日 12:40  分类 : 《关注互联网》  评论

点击全文阅读


目录

问题描述:

解决方法:

重要代码:


问题描述:

    项目中oracle数据库需要转换为mysql,Oracle中的表字段定义为number(36,16)类型的工具自动转换为mysql的decimal(36,16)。在Oracle数据库中,number(36,16)类型的字段,使用BigDecimal类型进行映射字段,能够正常获取到去除后缀0的值。MySQL数据库中存储为decimal(36,16)对应的字段,使用BigDecimal进行映射,会得到加后缀0的数值。例如在oracle中实际精度是16位的数值0.000345344,使用BigDecimal接收,会得到0.000345344,而mysql会得到的值为0.0003453440000000,这样返回给前端,就会有问题。这

解决方法:

1、按照业务需求,在mysql数据库下,修改每一个字段对应的精度。然后在代码中手动对BigDecimal类型的字段进行手动去0后缀处理。

2、在vo层进行json格式化中,进行去除0后缀。(这种方案不推荐,但要是想快速修改,可以采取)

重要代码:
package com.xiayu.config;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().doubleValue());            //去除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的价格

点击全文阅读


本文链接:http://zhangshiyu.com/post/166929.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1