数据库中id类型的问题

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

问题原因

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

解决办法

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

相关推荐
Flying pigs~~3 小时前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
misL NITL4 小时前
mysql之如何获知版本
数据库·mysql
许彰午4 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
2401_832365525 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
2301_779622416 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
2301_766283446 小时前
c++如何将控制台输出保存到文件_cout重定向到txt【详解】
jvm·数据库·python
北极的冰箱6 小时前
MySQL Ver 8.0.41 for macos14.7密码遗忘
数据库·mysql
XDH_CS6 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
treacle田7 小时前
达梦数据库-统计信息收集-记录
数据库·达梦数据库统计信息收集
审判长烧鸡8 小时前
PostgreSQL之索引/函数/触发器
数据库·postgresql·触发器·函数·索引