求解一个 Django ORM 相关的优化问题

2015-09-07 19:32:48 +08:00
 stage37
先上代码:

models.py

class TypeA (models.Model ):
    ...
    @property
    def field (self ):
        if self.typeb_set.count ():
            return self.typeb_set
    ...

class TypeB (models.Model ):
    ...
    typea = models.ForeignKey (TypeA )
    ...

其中 TypeA 和 TypeB 是一对多的关系。

templates/some_page.html

{% for item in items %}
  {% for obj in item.obj_list %} {# 此处的 obj 与 models.py 中的 TypeA 对应 #}
&ensp;&ensp;<ol>
&ensp;&ensp;&ensp;&ensp;<li>{ obj.f1 }</li>
&ensp;&ensp;&ensp;&ensp;<li>{ obj.f2 }</li>
&ensp;&ensp;&ensp;&ensp;<li>{ obj.f3 }</li>
&ensp;&ensp;&ensp;&ensp;<li>{ obj.field }</li>
&ensp;&ensp;</ol>
&ensp;&ensp;{% endfor %}
{% endfor %}

每次执行到{{ obj.field }}时都会查询一次 TypeB 对应的表,现在如果 obj 的个数非常多就会有很多次查询,严重影响页面加载速度。

查了下似乎 prefetch_related ()和 select_related ()跟这个问题相关,但是手册里介绍的跟上面这种情况有略有区别。

请问有什么优化的方法吗?
2626 次点击
所在节点    Python
3 条回复
ljdawn
2015-09-07 20:18:10 +08:00
就是用 related 呀
facert
2015-09-08 12:23:06 +08:00
foreignkey 用 select_related
stage37
2015-09-08 21:58:25 +08:00
@facert 搞定了,最后用的 prefetch_related ()。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/218935

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX