
1 PanJiaChen 2015 年 8 月 6 日 我不会 |
2 Sinic 2015 年 8 月 6 日 你是不是用了queryset.iterator()?使用iterator()无法生成cache,遍历同一个queryset时会重复执行查询。 |
3 virusdefender 2015 年 8 月 6 日 逆循环的时候是不是涉及到每一项的外键的内容了? 如果是这样的话,一次查出来就好了。https://docs.djangoproject.com/en/1.8/ref/models/querysets/#select-related |
4 onlyice 2015 年 8 月 6 日 猜测跟 Django 的 lazy query 没有关系。。 可能是你的 Model 有 Relation,用 prefetch_related 试试 |
5 zhuangzhuang1988 2015 年 8 月 6 日 贴关键代码, Django应该也不会3000条就生成出3000个查询语句的 |
6 tudou527 2015 年 8 月 7 日 同问,肯定是楼主代码的问题。 |
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 ,大幅度提高了性能哈 |