在我们的应用程序中,当用户创建订单时,我们将获得下一个订单#,如下所示:
SELECT MAX(CAST(REPLACE(orderNum, 'SO', '') AS SIGNED)) + 1 FROM orders
问题在于,由于客户越来越忙,我们开始看到在完全相同的时间创建的订单导致重复的订单#。
处理此问题的最佳方法是什么?我们应该锁定整个订单表还是仅锁定行?或者我们应该做交易吗?
答案 0 :(得分:0)
您可以使用一个具有auto_increment属性的字段创建一个额外的表。 现在,每当您需要一个新的订单号时,您调用一个函数将在该表中创建一个字段并返回last_insert_id()的结果,然后您可以将其用作订单号(只需确保设置auto_increment计数器)表格高于您的最大订单号。)