1
PanJiaChen 2015-08-06 17:06:03 +08:00
我不会
|
2
Sinic 2015-08-06 18:21:31 +08:00
你是不是用了queryset.iterator()?使用iterator()无法生成cache,遍历同一个queryset时会重复执行查询。
|
3
virusdefender 2015-08-06 19:27:11 +08:00
逆循环的时候是不是涉及到每一项的外键的内容了?
如果是这样的话,一次查出来就好了。https://docs.djangoproject.com/en/1.8/ref/models/querysets/#select-related |
4
onlyice 2015-08-06 19:29:11 +08:00
猜测跟 Django 的 lazy query 没有关系。。
可能是你的 Model 有 Relation,用 prefetch_related 试试 |
5
zhuangzhuang1988 2015-08-06 22:56:34 +08:00
贴关键代码, Django应该也不会3000条就生成出3000个查询语句的
|
6
tudou527 2015-08-07 09:27:52 +08:00
同问,肯定是楼主代码的问题。
|
7
pc10201 OP @zhuangzhuang1988
关键代码: 视图中的 items = Exams.objects.raw(""" SELECT * from exams,vendor WHERE exams.vendor_id=vendor.id ORDER BY vendor.name asc,exams.`code` ASC""") exams 模板中的 {% for item in items %} <tr> <th scope="row">{{ forloop.counter }}</th> <td><a href="{% url 'exam' item.code %}">{{ item.code }}</a></td> <td>{{ item.vendor.name }}</td> <td>{{ item.name }}</td> </tr> {% endfor %} Exams表中的vendor是外键,关联vendor表 |
8
pc10201 OP @virusdefender 是的,我用了 select-related ,大幅度提高了性能哈
|