![]() | 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 ,大幅度提高了性能哈 |