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

打印 上一主题 下一主题

主题 998|帖子 998|积分 2994

目次
问题描述:
办理方法:
重要代码:


问题描述:

    项目中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后缀。(这种方案不推荐,但要是想快速修改,可以接纳)
重要代码:

  1. package com.xiayu.config;
  2.   import com.fasterxml.jackson.core.JsonGenerator;
  3.   import com.fasterxml.jackson.databind.JsonSerializer;
  4.   import com.fasterxml.jackson.databind.SerializerProvider;
  5.   import java.io.IOException;
  6.   import java.math.BigDecimal;
  7.   import java.util.Objects;
  8.   public class CustomerBigDecimalSerialize extends JsonSerializer<BigDecimal> {
  9.       @Override
  10.       public void serialize(BigDecimal value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
  11.           if(Objects.nonNull(value)) {
  12.               gen.writeNumber(value.stripTrailingZeros().doubleValue());
  13.               //去除0后缀,如果想统一进行保留精度,也可以采用类似处理
  14.           }else {//如果为null的话,就写null
  15.               gen.writeNull();
  16.           }
  17.       }
  18.   }
  19.   
  20.   //在vo类字段中对字段加上@JsonSerialize注解
  21.   @JsonSerialize(using = CustomerBigDecimalSerialize.class)
  22.   private BigDecimal totalExchangeBtc; //抵扣电费的usdt兑换的btc总量
  23.   @JsonSerialize(using = CustomerBigDecimalSerialize.class)
  24.   private BigDecimal perTotalExchangeBtc; //兑换的btc总量对应每份的btc
  25.   @JsonSerialize(using = CustomerBigDecimalSerialize.class)
  26.   private BigDecimal exchangeUsdtPrice; //兑换时usdt的价格
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

用户云卷云舒

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表