欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java Long类型转为json后数据损失精度的处理方式

程序员文章站 2022-03-04 12:06:09
目录数据库表结构设计abumtip类根据外键abum_id在数据库中查询的结果controller查到的结果chrome浏览器preview结果解决的方法方法一方法二方法三最近在项目开发中,使用spr...

最近在项目开发中,使用spring boot+mybatis的架构,数据库设计主键id时定义为bigint类型,使用mybatis的自动生成代码后没注意,主键在pojo里的类型为long。查询时获取的对象列表取出的数值没有问题,但转为json传到前端后,id的数据始终不是数据库查出来的那个。

数据库表结构设计

java Long类型转为json后数据损失精度的处理方式

abumtip类

java Long类型转为json后数据损失精度的处理方式

根据外键abum_id在数据库中查询的结果

java Long类型转为json后数据损失精度的处理方式

controller查到的结果

java Long类型转为json后数据损失精度的处理方式

chrome浏览器preview结果

java Long类型转为json后数据损失精度的处理方式

可以看到abumid(对应表abum_id)和tipid(对应表中tip_id)查询到的long类型的数据都不对。

解决的方法

方法一

重新生成pojo对象,将所有数据库类型为bigint都映射成string类型。

方法二

对于使用springboot,则增加配置代码:

package com.gj.app.config; 
import com.fasterxml.jackson.databind.objectmapper;
import com.fasterxml.jackson.databind.module.simplemodule;
import com.fasterxml.jackson.databind.ser.std.tostringserializer;
import org.springframework.context.annotation.configuration;
import org.springframework.http.converter.httpmessageconverter;
import org.springframework.http.converter.json.mappingjackson2httpmessageconverter;
import org.springframework.web.servlet.config.annotation.enablewebmvc;
import org.springframework.web.servlet.config.annotation.webmvcconfigureradapter; 
import java.util.list;
 
@enablewebmvc
@configuration
public class webdataconvertconfig extends webmvcconfigureradapter {
        public void configuremessageconverters(list<httpmessageconverter<?>> converters) {
            mappingjackson2httpmessageconverter jackson2httpmessageconverter = new mappingjackson2httpmessageconverter();
            objectmapper objectmapper = new objectmapper();
            /**
             * 序列换成json时,将所有的long变成string
             * 因为js中得数字类型不能包含所有的java long值
             */
            simplemodule simplemodule = new simplemodule();
            simplemodule.addserializer(long.class, tostringserializer.instance);
            simplemodule.addserializer(long.type, tostringserializer.instance);
            objectmapper.registermodule(simplemodule);
            jackson2httpmessageconverter.setobjectmapper(objectmapper);
            converters.add(jackson2httpmessageconverter);
        }
}

方法三

在spring mvc中

增加类:

其中longtostringjsonconverter为自定义转换器

public class longtostringjsonconverter extends objectmapper {
    /**
     * 
     */
    private static final long serialversionuid = 1683531771040674386l;
 
    @override
    public objectmapper registermodule(module module) {
        simplemodule simplemodule = new simplemodule();
        simplemodule.addserializer(long.class, tostringserializer.instance);
        simplemodule.addserializer(long.type, tostringserializer.instance);
        return super.registermodule(simplemodule);
    }
}
  <mvc:annotation-driven  conversion-service="conversionservice">
        <mvc:message-converters>  
           <bean class="org.springframework.http.converter.json.mappingjackson2httpmessageconverter">  
               <property name="objectmapper">  
                    <!-- <bean class="com.fasterxml.jackson.databind.objectmapper">   -->
                    <bean class="mypackage.longtostringadapter">
                        <property name="dateformat">  
                            <bean class="java.text.simpledateformat">  
                                <constructor-arg type="java.lang.string" value="yyyy-mm-dd hh:mm:ss" />  
                            </bean>  
                        </property>  
                    </bean>   
               </property>
           </bean>
        </mvc:message-converters>  
    </mvc:annotation-driven>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。