gpt4 book ai didi

mysql - 通过锁定或事务来防止重复数据?

转载 作者:行者123 更新时间:2023-11-30 01:35:42 27 4
gpt4 key购买 nike

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

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

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

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

最佳答案

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

关于mysql - 通过锁定或事务来防止重复数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16926613/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com