使用锁定或事务防止重复数据?

时间:2013-06-04 20:11:47

标签: mysql locking innodb

在我们的应用程序中,当用户创建订单时,我们将获得下一个订单#,如下所示:

SELECT MAX(CAST(REPLACE(orderNum, 'SO', '') AS SIGNED)) + 1 FROM orders

问题在于,由于客户越来越忙,我们开始看到在完全相同的时间创建的订单导致重复的订单#。

处理此问题的最佳方法是什么?我们应该锁定整个订单表还是仅锁定行?或者我们应该做交易吗?

1 个答案:

答案 0 :(得分:0)

您可以使用一个具有auto_increment属性的字段创建一个额外的表。 现在,每当您需要一个新的订单号时,您调用一个函数将在该表中创建一个字段并返回last_insert_id()的结果,然后您可以将其用作订单号(只需确保设置auto_increment计数器)表格高于您的最大订单号。)