gpt4 book ai didi

python - Django 模型检索相同的结果

转载 作者:太空狗 更新时间:2023-10-29 21:59:56 25 4
gpt4 key购买 nike

我有一个基于 SQL 数据库的 Django 模型 TestModel。

无论何时

TestModel.objects.all()

如果我从同一个进程多次运行它,我似乎得到了相同的结果。我测试了通过手动删除(不使用任何 Django 基元)从构建模型的表中的一行,查询仍然返回相同的结果,即使删除后显然应该有更少的对象。

是否有某种缓存机制,每次我想检索对象时,django 不会去数据库?

如果有,我是否仍然可以强制 django 在每次查询时转到数据库,最好不编写原始 SQL 查询?

我还应该指定通过重新启动进程,模型再次返回正确的对象,我不再看到已删除的对象,但如果我再删除一些,问题会再次发生。

最佳答案

这是因为你的数据库隔离级别是repeatable read。在 django shell 中,所有请求都包含在一个事务中。

已编辑

您可以在您的 shell 中尝试:

from django.db import transaction
with transaction.autocommit():
t = TestModel.objects.all()
...

关于python - Django 模型检索相同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13767459/

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