日常BUG——使用Long类型作id,后端返回给前段后精度丢失问题

  • 😜 是江迪呀
  • ✒️本文关键词日常BUGBUG问题分析
  • ☀️每日 一言存在错误说明你在进步!

一、问题描述

数据库long类型Id:

前端返回的Id实体类:

java 复制代码
@Data
@ApiModel("xxx")
public class TestVO{
    @ApiModelProperty("id")
    private Long id;
    ...
}

前端拿到的Id:

java 复制代码
{
"id": 1535525132997402600,
"attributeCode": "COLOR",
"attributeName": "颜色2",
"attributeDesc": "颜色2",
"createTime": "2022-06-11 15:31:35",
"createUser": "test"
},

二、问题原因

这是因为使用Long类型作id时,前后端交互时数据在网络上传输会导致精度丢失。

三、问题解决

在返回给前端的Dto类中,在Id上面加上下面的注解即可:

java 复制代码
@JsonSerialize(using = ToStringSerializer.class)

这样id就正常了

java 复制代码
{
    "id": "1535525132997402625",
    "attributeCode": "COLOR",
    "attributeName": "颜色2",
    "attributeDesc": "颜色2",
    "createTime": "2022-06-11 15:31:35",
    "createUser": "test"
},

},

如果前端要传给后端id的话,也会造成上面的问题。解决办法是前端将Long类型的字段转为String,后端在将String 转为Long即可。

相关推荐
光泽雨2 分钟前
mysql中的事务
数据库·mysql
黑牛儿3 分钟前
MySQL 备份与恢复详细步骤(新手版)
数据库·mysql·dba
fundoit4 分钟前
MySQL问题收集
数据库·人工智能·mysql·智能体
计算机学姐6 分钟前
基于SpringBoot的在线学习网站平台【个性化推荐+数据可视化+课程章节学习】
java·vue.js·spring boot·后端·学习·mysql·信息可视化
Chasing__Dreams19 分钟前
Mysql--基础知识点--94.1--嵌套子查询转关联查询
数据库·mysql
qq_2837200520 分钟前
Python 操作 MySQL 数据库全解:增删改查、事务、连接池与性能优化
数据库·python·mysql
爱码小白21 分钟前
MySQL 系统函数专项练习题
数据库·python·mysql
Chasing__Dreams22 分钟前
Mysql--基础知识点--97--UNION ALL VS UNION
数据库·mysql
SPC的存折31 分钟前
3、MySQL数据库主从复制
linux·运维·服务器·数据库·mysql
知己呀38 分钟前
MySQL主从延迟根因诊断与优化指南
经验分享·mysql·面试·八股文·主从延迟