项目场景:
使用SpringBoot+Mybatis-plus时返回到前端的数据
与后端查询的结果不一致
问题描述
后端接口怼完了,给前端一返回,发现给下个请求的参数查不到数据
,我看数据库是有的,就就发现了这个奇怪的问题
。
先看一下前端浏览器的结果吧:
- 这是浏览器请求后得到的原始数据
- 这是浏览器请求后得到的预览数据
发现:
结果不一样,预览数据和我用console.log()
打印请求结果的数据一样
再来看看我后端Debug的样子:
查询的结果正常,正常的id字段值就是这个1513205139986870274
再来看看swagger
的请求结果:
这里的id字段的值
和浏览器预览的值
(即前端使用的结果
)是错误的
再看下Postman
的请求结果:
Postman
请求的结果是正确的
到这里是不是感觉特别奇怪
,有的小伙伴可能已经猜到原因了,但是我不知道,(哭~~)
原因分析:
经过了 一圈的询问,发现了原因,就是这个id字段的类型是Long
返回给前端后,前端识别为了number类型
,但是这个id的长度超过了number类型的长度
,所以才导致了精度的丢失
(也就是上面的数据不一致的问题)
解决方案:
将后台的id字段处理成字符串类型
(Long->String
);
我这里就直接修改数据库(varchar)
和实体类的类型(String)
就此完美解决~~~~