首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何安全地将递增ID分配给对象的子集?

如何安全地将递增ID分配给对象的子集?
EN

Stack Overflow用户
提问于 2011-11-30 11:42:15
回答 2查看 66关注 0票数 0

我有一个Order对象,它可以处于未支付或已支付状态。当订单支付时,我想设置一个order_number,它应该是一个递增的数字。

听起来很简单,但我担心会发生碰撞。我可以想象一个订单在内存中存储了一个order_number,准备保存,然后另一个订单保存了自己,使用这个数字,现在内存中的订单应该重新计算,但如何计算呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-11-30 11:54:50

您可以创建一个只包含AUTO_INCREMENT主键的数据库表。当您需要获取一个新的order_number时,只需对该表执行一次插入操作,并获取所创建行的主键的值。

票数 0
EN

Stack Overflow用户

发布于 2011-11-30 12:01:48

有很多方法。本质上,您需要一个锁来确保对计数器的每个请求总是返回不同的值。

Memcache、Redis和一些键值存储都有这种计数器特性。例如,每次你想要获取一个新的order_number,只要调用Redis的incr命令,它就会递增计数器并返回新值。

更复杂的解决方案可以通过RMDBS的触发器/存储过程/序列特性(如mysql)来实现。对于mysql,新建一个包含AUTO_INCREMENT主键的表。当您想要获取一个新的order_number时,在这个表中插入并获取last_insert_id()。如果需要ACID,只需将过程包装在事务中即可。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8320882

复制
相关文章

相似问题

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