gpt4 book ai didi

mysql - 为什么 "select_for_update()"不能在 Django 和 MySQL 中一起工作?

转载 作者:行者123 更新时间:2023-11-29 10:02:51 27 4
gpt4 key购买 nike

我有一个如下表:

SELECT id, name FROM node;
+----+------+
| id | name |
+----+------+
| 5 | na |
+----+------+

然后定义以下函数:

>>> def foo_with_sfu(seconds):
... with transaction.atomic():
... node = Node.objects.select_for_update().filter(pk=5)
... time.sleep(seconds)
... node = Node.objects.get(pk=5)
... print(node.name)
...

我希望 select_for_update 会锁定行 pk=5,因此如果我在 time.sleep 期间打开另一个控制台来更改 node.name,则更改操作将被阻止。

但实际上,当我运行该函数,并在 time.sleep 期间在另一个控制台中运行 update sql 时,更新并未被阻止。

更新的选择似乎没有锁定该行。为什么?

最佳答案

您的 select_for_update() 查询永远不会被评估,因此锁永远不会在数据库上执行。请参阅the documentation了解何时以及如何评估查询集。

如果您只是将调用包装在查询集评估函数中,您的测试应该可以工作。例如:

with transaction.atomic():
node = list(Node.objects.select_for_update().filter(pk=5))

关于mysql - 为什么 "select_for_update()"不能在 Django 和 MySQL 中一起工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52547672/

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