首页 > 作文

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

更新时间:2023-04-04 14:22:03 阅读: 评论:0

目录
数据库表结构设计abumtip类根据外键abum_id在数据库中查询的结果controller查到的结果chrome浏览器preview结果解决的方法方法一方法二方法三

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

数据库表结构设计

abumtip类

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

cont猴子观海roller查到的结果

chrome浏览器preview结果

可以看到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.r.std.tostringrializer;import org.springframework.context.annotation.configuration;import org.springframework.h仿编儿歌ttp.converter.httpmessageconverter;import org.springframework.http.converter.json.mappingjackson2httpmessageconverter;import org.springframework.web.rvlet.config.annotation.enablewebmvc;import org.springframework.web.rvlet.config.annotation.webmvcconfigureradapter; import java.util.list; @enablewebmvc@configurationpublic 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.addrializer(long.class, tostringrializer.instance);            simplemodule.addrializer(long.type, tostringrializer.instance);            objectmapper.registermodule(simplemodule);            jackson2httpmessageconverter.tobjectmapper(objectmapper);            converters.add(jackson2httpmessageconverter);        }}

方法三

在spring mvc中

增加类:

其中longtostringjsonconverter为自定义转换器

public class longtostringjsonconverter extends objectmapper {    /**     *      */    private static final long rialversionuid = 1683531771040674386l;     @override    public objectmapper registermodule(module module) {        simplemodule simplemodule = new simplemodule();        simplemodule.addrializer(long.class, tostringrializer.instance);        simplemodule.addrializer(long.type, tostringrializer.instance);        return super.registermodule(simplemodule);    }}
  <mvc:annotation-driven  conversion-rvice="conversionrvice">        <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="date写给未来自己的一封信format">         科举制的意义                     <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>

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

本文发布于:2023-04-04 14:22:02,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/8daab53bb4d64530148c1ba25a1991d8.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:java Long类型转为json后数据损失精度的处理方式.doc

本文 PDF 下载地址:java Long类型转为json后数据损失精度的处理方式.pdf

标签:方法   类型   数据库   数据库中
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图