ForeignKey null=True 时 Django 慢查询

Posted

技术标签:

【中文标题】ForeignKey null=True 时 Django 慢查询【英文标题】:Django slow query when ForeignKey null=True 【发布时间】:2012-12-31 06:08:49 【问题描述】:

我在我的 Django 模型中的 ForeignKey 字段之一上设置了 null=True,现在当我查询该模型时,它的速度大约慢了 10 倍。 (我用的是select_related()

在更改前后查看我的 Postgres 日志可以找到原因的线索:

在设置null=True 之前,生成的SQL 是带有几个内部连接的单个select 语句。 设置null=True 后,生成的SQL 会忽略其中一个连接,而后跟数千个相同的选择语句。

所以这是经典的 n+1 查询问题,until this is fixed,我怎样才能在 ForeignKey 字段上设置 null=True 而不会影响性能?

【问题讨论】:

您是否通过 depth 参数或字段名称限制了 select_related 没有限制,有帮助吗? 也许您的故障不仅仅针对null=True 【参考方案1】:

从官方文档来看,就是select_related()方法的局限性,here is the details。

但您可以在select_relate() 中指定相关字段,例如

modelA.objects.select_related('ModelAForeignKeyName__RelatedModelFeildName')

【讨论】:

【参考方案2】:

您可以通过raw query 解决此问题。查看在输入null=True 之前生成的查询,并通过raw 查询而不是使用“***django ORM”执行它。故障是由于 ORM 不在 Postgres 服务器上,所以可以避免直接运行 SQL 代码生成无用代码。

【讨论】:

这是一个不错的解决方案。我试试看。

以上是关于ForeignKey null=True 时 Django 慢查询的主要内容,如果未能解决你的问题,请参考以下文章

尽管空白 = True 和 null = True,但需要 Django ForeignKey 字段

Django:限制 models.ForeignKey 结果

找不到与 Django ForeignKey 问题相关的类

Django:ForeignKey 的值可以是 None 吗?

Django:扩展用户时,最好使用 OneToOneField(User) 或 ForeignKey(User, unique=True)?

Django South 迁移不适用于 null = True 和空白 = True