Перебор связанных объектов в Django :цикл по набору запросов или использование одного -лайнера select _связанного (или предварительной выборки _связанного)

У меня есть приложение для рассылки новостей, в котором в каждом выпуске есть несколько статей. Я хочу отобразить сводную страницу в Интернете, на которой перечислены год, объем и метка информационного бюллетеня, а затем в неупорядоченном списке отобразить все статьи в выпуске. Я новичок в Django, поэтому я пытаюсь определить лучший способ сделать это.

У меня есть модели, определенные (только соответствующие части):

Models.py:

class Newsletter(models.Model):
    volume = models.ForeignKey(Volume)
    year   = models.IntegerField()
    season = models.CharField(max_length=6, choices=VOLUME_SEASON)
    label  = models.CharField(max_length=20)
    number = models.IntegerField()

class Article(models.Model):
    newsletter = models.ForeignKey(Newsletter)
    section    = models.ForeignKey(Section)
    title      = models.CharField(max_length=200)

То, что я хочу видеть в сети, выглядит так:

<h2>Spring 2012</h2>
<p>Volume 14, Number 1</p>
<ul>
    <li>Foo</li>
    <li>Bar</li>
    <li>Baz</li>
</ul>

<h2>Winter 2011</h2>
<p>Volume 13, Number 4</p>
<ul>
  <li>Boffo</li>
</ul>

Довольно просто. Тем не менее, я смущен тем, как лучше всего написать свое мнение. Использовать ли:

  • Два списка, которые я zip(), а затем повторяю в шаблоне
  • Используйте набор запросов select_related()
  • Используйте набор запросов prefetch_related()

У меня работает по первому варианту:

Views.py:

from django.shortcuts import render_to_response, get_object_or_404
from www.apps.newsletter.models import Newsletter, Article

def index(request):
    article_group = []
    newsletter = Newsletter.objects.all().order_by('-year', '-number')
    for n in newsletter:
        article_group.append(n.article_set.all())
    articles_per_newsletter = zip(newsletter, article_group)

    return render_to_response('newsletter/newsletter_list.html',
                              {'newsletter_list': articles_per_newsletter})

А затем визуализируйте его, используя следующий шаблон:

Newsletter_list.html:

{% block content %}
  {% for newsletter, articles in newsletter_list %}
    <h2>{{ newsletter.label }}</h2>
    <p>Volume {{ newsletter.volume }}, Number {{ newsletter.number }}</p>
    <p>{{ newsletter.article }}</p>
    <ul>
    {% for a in articles %}
      <li>{{ a.title }}</li>
    {% endfor %}
    </ul>
  {% endfor %}
{% endblock %}

Довольно просто, но, поскольку я новичок в Django, мне было интересно, не является ли то, что я делаю, совершенно неэффективным с точки зрения его мощного ORM.Я хотел бы не составлять список -на -лету, а затем zip()два списка вместе, если есть более быстрый способ.

ТИА.

15
задан Santosh Kumar 18 August 2012 в 10:22
поделиться