Django:select_related到一个表vs表的字段

Posted

技术标签:

【中文标题】Django:select_related到一个表vs表的字段【英文标题】:Django: select_related to a table vs table's field 【发布时间】:2018-02-22 23:43:42 【问题描述】:

我有 2 个模型

class A(models.Model):
    val = models.IntegerField()

class B(models.Model):
    val2 = models.IntegerField()
    a = models.ForeignKey(A)

class C(models.Model):
    b = models.ForeignKey(B)
    val3 = models.IntegerField()

查询结果如何——

C.objects.select_related('B').all()

优于-

C.objects.select_related('B__val2').all()

如果不是,如何优化查询?

【问题讨论】:

【参考方案1】:

尝试通过子模型的小写过滤器过滤您需要的模型

B.objects.filter(c__isnull=False)

在此处阅读更多信息lookups-that-span-relationships

【讨论】:

过滤是另一种方法。但是,如果可以以某种方式引用模型的字段,那就更好了。

以上是关于Django:select_related到一个表vs表的字段的主要内容,如果未能解决你的问题,请参考以下文章

Django:4个表中的select_related() / prefetch_related()

Django select_related 不显示所有字段,但原始 SQL 显示

Django select_related 查询不会将所有值返回到模板

django: select_related() 在一个已经存在的对象上?

详解Django的 select_related 和 prefetch_related 函数对 QuerySet 查询的优化

Django中的左外反向select_related?