我有一个Order对象,它可以处于未支付或已支付状态。当订单支付时,我想设置一个order_number,它应该是一个递增的数字。
听起来很简单,但我担心会发生碰撞。我可以想象一个订单在内存中存储了一个order_number,准备保存,然后另一个订单保存了自己,使用这个数字,现在内存中的订单应该重新计算,但如何计算呢?
发布于 2011-11-30 11:54:50
您可以创建一个只包含AUTO_INCREMENT主键的数据库表。当您需要获取一个新的order_number时,只需对该表执行一次插入操作,并获取所创建行的主键的值。
发布于 2011-11-30 12:01:48
有很多方法。本质上,您需要一个锁来确保对计数器的每个请求总是返回不同的值。
Memcache、Redis和一些键值存储都有这种计数器特性。例如,每次你想要获取一个新的order_number,只要调用Redis的incr命令,它就会递增计数器并返回新值。
更复杂的解决方案可以通过RMDBS的触发器/存储过程/序列特性(如mysql)来实现。对于mysql,新建一个包含AUTO_INCREMENT主键的表。当您想要获取一个新的order_number时,在这个表中插入并获取last_insert_id()。如果需要ACID,只需将过程包装在事务中即可。
https://stackoverflow.com/questions/8320882
复制相似问题