gpt4 book ai didi

mysql - 使用 mysql innodb 作为队列?

转载 作者:行者123 更新时间:2023-11-30 23:40:42 26 4
gpt4 key购买 nike

我从 mysql 表中提取了两个作业。他们都想获得一行,对其进行一些处理并用结果更新该行,但是我不希望他们选择同一行进行更新。使用 mysql/innodb 引擎锁定 select 中的一行的最佳方法是什么,这样它对其他线程不可用但允许他们选择其他记录?这可能吗?

谢谢!

最佳答案

您可以将“FOR UPDATE”修饰符添加到选择语句的末尾。即

SELECT * FROM table WHERE pkey = N FOR UPDATE;

.. 但我认为在使用 InnoDB 作为队列并以性能为目标时应该小心。队列是面向堆栈的,并且需要与 InnoDB(和 MySQL)试图解决的问题不同的工具。

关于mysql - 使用 mysql innodb 作为队列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3326707/

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