数据库中id类型的问题

今天在构建id时发现一个很大的坑,我自己在编写在数据库中创建一条记录的接口时,由于需要将id转化为uuid7/雪花算法的方式存储(防止业务信息泄露),此处我选择的是uuid7的方式来进行实现的这个功能的,但是此处有一个问题,数据库中存储时是使用Bigint的方式进行存储,但是返回给前端(使用的fastapi的docs文档来进行测试)处理时,由于前端处理int时,int类型的精度时达不到数据库中的bigint的类型,所以此处会导致前端接口返回的id与数据库中的id不对应,导致后续的操作无法进行。

问题原因

前端的最大精度是53 位(9007199254740991),如果处理过大的int数据(例如使用uuid7进行处理后的id)会导致超出精度,导致呈现的数据和后端返回的数据不一致,所以此处就需要后端进行处理,使用str的方式进行返回,这样就不会出现问题,最后

解决办法

此处解决办法倒不是很难,需要后端中返回数据的类型进行转化,即在返回结构体中将数据库中的id先转化为str类型后再进行返回。

相关推荐
czlczl200209255 小时前
双 Token 机制下的无感刷新(Refresh Token)后端实现
数据库·spring boot·redis·后端·mysql
宠..6 小时前
创建单选按钮控件
java·服务器·数据库
李慕婉学姐6 小时前
Springboot社会工作机构管理系统w19724cv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
杰克尼6 小时前
mysql_day2总结
数据库·mysql
九河云6 小时前
华为云 DRS 数据复制服务:数据库无缝迁移上云的零停机实践
大数据·数据库·华为云
姓蔡小朋友6 小时前
MySQL多表查询
数据库·mysql
云飞云共享云桌面6 小时前
SolidWorks服务器怎么实现研发软件多人共享、数据安全管理
java·linux·运维·服务器·数据库·自动化
Elastic 中国社区官方博客7 小时前
Elasticsearch:使用 ES|QL 与 dense_vector 字段
大数据·数据库·人工智能·sql·elasticsearch·搜索引擎·全文检索
Channing Lewis7 小时前
mysql.connector.errors.OperationalError: 1040 (08004): Too many connections
数据库·mysql·adb