当前位置: 首页 > news >正文

Java列表查询Long(id)到前端转换出错

Java列表查询Long到前端转换出错

  • 问题描述
  • 排查思路
    • 思路一:SQL问题
    • 思路二:Long类型转换出错
  • 解决方法

问题描述

做了一个列表查询功能,本来不应该有啥大问题的,但是往往事与愿违。
诶,你越觉得不可能出问题,他就越出问题了😬,就是玩。
报了一个“Duplicate keys detected: ‘7918899278313947000’”的问题,ID重复了?
我打开F12一看,卧槽!!!真的重复了🤨
在这里插入图片描述重复了那就找问题呗😮‍💨

排查思路

思路一:SQL问题

像这种主键重复第一反应就是是不是SQL写的不对,尤其是多表关联插叙。
于是排查了一顿SQL,发现没啥问题啊,巴对🫤
在这里插入图片描述直到返回前端的page对象中,ID都是不重复的。
但是到了前端之后ID就变一样了🤔这。。。。

思路二:Long类型转换出错

经过对比发现一个问题,就是前16位是一样的,后3位都变成0了。😯😮
在这里插入图片描述于是又有了一个想法,就是在数据传输的过程中,Long类型转化出错了,导致后三位都变成0了。

那就朝着这个方向继续努力💪💪💪

考大家基础知识的时间到了。

Java的八大基本数据类型
整型:byte(1字节8bit)、short(2字节16bit)、int(4字节32bit)、long(8字节64bit)
字符型:char(2字节16bit)
浮点型:float(4字节32bit)、double(8字节64bit)
布尔型:boolean(仅有两个值true, false,变量初始化默认值false

在Java中,long类型是一种表示大整数的数据类型。它使用64位(8字节)的存储空间,可以表示的整数范围从-9223372036854775808到9223372036854775807。

long类型的长度最长为19,刚好数据库id字段的长度就是19😔,但是可以看到显然还不到最大值,如果超过最大值数据入库的时候就会报错,也不会成功入库😓

但是还有一个long类型的字段长度为16,传到前端后数据一致🤨,这是不是说明long类型达到19后会出现意想不到到的错误,导致值发生变化,那就简单粗暴一点,在后端直接转化成String类型就好了😁。

解决方法

找到实体类,在id的字段上fastjson的@JSONField注解转化成字符串就OK了。

import com.alibaba.fastjson.annotation.JSONField;
import com.alibaba.fastjson.serializer.ToStringSerializer;

在这里插入图片描述

    @JSONField(serializeUsing = ToStringSerializer.class)private Long id;

在这里插入图片描述

在这里插入图片描述问题解决!!!😀😄😆
打完收工!

http://www.lryc.cn/news/177482.html

相关文章:

  • react import爆红
  • ThreeJS-3D教学三:平移缩放+物体沿轨迹运动
  • 玩玩“小藤”开发者套件 Atlas 200I DK A2 之VSCode远程连接
  • 安装python中tensorflow和keras==2.2.0的路程
  • Linux命令历史记录管理:使用history命令提高工作效率
  • Armv9 Cortex-A720的L1 memory system 和 L1 Cache
  • 使用超声波清洗机洗眼镜有哪些注意事项、高颜值超声波清洗机推荐
  • 23种设计模式汇总详解
  • stream流的filter和map过滤
  • Linux 环境下使用 Docker 部署 Seata 1.7.1 (图文教程)
  • Aruba CX交换机 VSF配置
  • 使用ElementUI结合Vue完善主页的导航菜单和书籍管理以及后台数据分页查询
  • 子序列问题集合
  • idea中提示:error has occurred, please check your installation and try again
  • MySQL - 关于约束类型和作用的介绍
  • 【2023集创赛】芯原杯一等奖作品:基于芯原DSP核的智能语音SoC设计
  • 代理IP与Socks5代理在跨界电商、爬虫、游戏和网络安全中的应用
  • DDS信号发生器Verilog波形发生器FPGA
  • 基于springboot实现二手交易平台管理系统演示【项目源码】分享
  • 一个链接分享自制的产品图册
  • 2023工博会 | 上海添力网络营销公司 | 助力工业品线上推广
  • React实现多图片预览功能、预览图上下张切换(实战示例)
  • 【NLP的Python库(04/4)】:Flair
  • Vue框架学习大纲
  • 利用PPT导出一张高清图的方法,office与WPS只需要使用一个即可,我使用的是office。
  • 2023年【四川省安全员B证】最新解析及四川省安全员B证模拟考试
  • 某瑞集团安全技术研发岗位面试
  • 学习笔记|ADC反推电源电压|扫描按键(长按循环触发)|课设级实战练习|STC32G单片机视频开发教程(冲哥)|第十八集:ADC实战
  • 2020 款凯迪拉克 XT5 车发动机加速异响
  • 【AI视野·今日CV 计算机视觉论文速览 第255期】Wed, 27 Sep 2023