教育网站平面设计53建筑人才网
news/
2025/10/6 9:04:55/
文章来源:
教育网站平面设计,53建筑人才网,网站策划软件,住房和城乡建设部网站建造师目录
问题描述:
解决方法:
重要代码#xff1a; 问题描述: 项目中oracle数据库需要转换为mysql#xff0c;Oracle中的表字段定义为number(36,16)类型的工具自动转换为mysql的decimal(36,16)。在Oracle数据库中#xff0c;number(36,16)类型的字段#xff0c;使用BigDeci…目录
问题描述:
解决方法:
重要代码 问题描述: 项目中oracle数据库需要转换为mysqlOracle中的表字段定义为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 JsonSerializerBigDecimal {Overridepublic void serialize(BigDecimal value, JsonGenerator gen, SerializerProvider serializers) throws IOException {if(Objects.nonNull(value)) {gen.writeNumber(value.stripTrailingZeros().doubleValue());//去除0后缀,如果想统一进行保留精度也可以采用类似处理}else {//如果为null的话就写nullgen.writeNull();}}}//在vo类字段中对字段加上JsonSerialize注解JsonSerialize(using CustomerBigDecimalSerialize.class)private BigDecimal totalExchangeBtc; //抵扣电费的usdt兑换的btc总量JsonSerialize(using CustomerBigDecimalSerialize.class)private BigDecimal perTotalExchangeBtc; //兑换的btc总量对应每份的btcJsonSerialize(using CustomerBigDecimalSerialize.class)private BigDecimal exchangeUsdtPrice; //兑换时usdt的价格
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/929134.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!