日常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即可。

相关推荐
哈里谢顿7 小时前
MySQL 索引失效的 12 宗罪:一条 SQL 是怎样把索引踢出执行计划的?
mysql
laocooon5238578867 小时前
mysql,100个题目。
数据库·sql·mysql
funfan05178 小时前
【运维】MySQL数据库全量备份与恢复实战指南:从入门到精通
运维·数据库·mysql
液态不合群10 小时前
【面试题】MySQL 三层 B+ 树能存多少数据?
java·数据库·mysql
JAVA+C语言10 小时前
MySQL 9.0 最新版本从安装到使用
mysql
zhz521412 小时前
后端代码规范文档示例
重构·bug·代码规范·结对编程
吊睛白额鼠12 小时前
从Hive函数collect到MySQL函数group_concat
mysql
luoluoal13 小时前
基于python的语音和背景音乐分离算法及系统(源码+文档)
python·mysql·django·毕业设计·源码
·云扬·13 小时前
MySQL单机多实例部署两种实用方法详解
数据库·mysql·adb
洛小豆13 小时前
她问我:数据库还在存 Timestamp?我说:大人,时代变了
数据库·后端·mysql