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

相关推荐
blackA_25 分钟前
数据库MySQL学习——day4(更多查询操作与更新数据)
数据库·学习·mysql
qq_441996052 小时前
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
数据库·mysql·postgresql
AI军哥3 小时前
MySQL8的安装方法
人工智能·mysql·yolo·机器学习·deepseek
程序员不想YY啊3 小时前
MySQL元数据库完全指南:探秘数据背后的数据
数据库·mysql·oracle
柏油5 小时前
MySql InnoDB 事务实现之 undo log 日志
数据库·后端·mysql
jack xu16 小时前
高频面试题:如何保证数据库和es数据一致性
java·大数据·数据库·mysql·elasticsearch
炫彩@之星7 小时前
Mysql之UDF提权
mysql·udf提权
爱的叹息7 小时前
DeepSeek 大模型 + LlamaIndex + MySQL 数据库 + 知识文档 实现简单 RAG 系统
数据库·人工智能·mysql·langchain
橘猫云计算机设计7 小时前
net+MySQL中小民营企业安全生产管理系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·后端·爬虫·python·mysql·django·毕业设计
黄嚯嚯7 小时前
Mysql8.0 推出的强大功能 窗口函数(Window Functions)
数据库·mysql