首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >NoSQL/DynamoDB如何生成低字符主键?

NoSQL/DynamoDB如何生成低字符主键?
EN

Stack Overflow用户
提问于 2020-12-24 19:02:18
回答 1查看 32关注 0票数 1

我需要为一个Flask项目生成房间代码,其风格与https://jackbox.tv/类似。

这些房间代码将作为DynamoDB表中的主键,因此需要是唯一的。

一种选择是使用UUID,但是这些UUID非常大,并且不便于用户输入。有没有一种方法可以在不重复查询数据库的情况下生成简短的(~4-8个字符)、唯一的代码?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-24 19:26:49

您可以使用当前时间戳的base36表示,它将是8个字符的长度,并且重复的概率将非常低。在实践中,这样做效果很好。

代码语言:javascript
运行
复制
import base36
from datetime import datetime

key = base36.dumps(int(datetime.utcnow().timestamp() * 1000))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65437416

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档