gpt4 book ai didi

Django QuerySet 直接访问外键字段,不强制加入

转载 作者:行者123 更新时间:2023-12-04 15:37:23 27 4
gpt4 key购买 nike

假设您有一个模型条目,其中一个字段“作者”指向另一个模型作者。假设该字段可以为空。

如果我运行以下查询集:

Entry.objects.filter(作者=X)

其中 X 是某个值。假设在 MySQL 中,我在 Entry 上为其他一些列和 author_id 设置了一个复合索引,理想情况下,我希望 SQL 在 Entry 模型上只使用“author_id”,以便它可以使用复合索引。

结果证明 Entry.objects.filter(author=5) 可以工作,没有加入。但是,如果我说 author=None,Django 会与 Author 连接,然后添加到 Where 子句 Author.id IS NULL。所以在这种情况下,它不能使用复合索引。

有没有办法告诉 Django 只检查 pk,而不是按照链接?

我知道的唯一方法是向 QuerySet 添加一个额外的 .extra(where=['author_id IS NULL']),但我希望 .filter() 中的一些魔法会起作用。

谢谢。

(抱歉,我之前对此不太清楚,感谢 lazerscience 和 Josh 的回答)。

最佳答案

这不会按预期工作吗?

Entry.objects.filter(author=X.id)

您可以在外键过滤器中使用模型或模型 ID。如果这执行单独的查询,我还不能正确检查,尽管我真的希望它不会。

关于Django QuerySet 直接访问外键字段,不强制加入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4189125/

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