Запрос Django ORM: получение «имеет много» объектов отношений - PullRequest
1 голос
/ 20 августа 2010

Существует модель:

class DomainPosition(models.Model):
    domain   = models.ForeignKey(Domain)
    keyword  = models.ForeignKey(Keyword)
    date     = models.DateField()
    position = models.IntegerField()

    class Meta:
        ordering = ['domain', 'keyword']

Как получить записи позиций для шаблона, если для каждого домена я хочу отобразить следующую таблицу (цифры в таблице являются значениями позиций):

+----------+--------+--------+-------+--------
| keyword  | date1  | date2  | date3 | ...
+----------+--------+--------+-------+--------
| keyword1 |    2   |    6   |    7  |   ...
+----------+--------+--------+-------+--------
| keyword2 |    4   |   12   |    5  |   ...
+----------+--------+--------+-------+--------
| keyword3 |    6   |    3   |    9  |   ...
+----------+--------+--------+-------+--------

, где views.py:

def show_domain_history(request, domain_name):
    domain = Domain.objects.filter(name__contains=domain_name)
    if not domain:
        return HttpResponseRedirect('/')
    else:
        # positions = ...
        variables = RequestContext(request, {
            'domain':    domain[0].name,
            'positions': positions,
        })
        return render_to_response('history.html', variables)

Ответы [ 2 ]

1 голос
/ 20 августа 2010
def show_domain_history(request, domain_name):
    domain = Domain.objects.filter(name__contains=domain_name)
    if not domain:
        return HttpResponseRedirect('/')
    else:
        variables = {'domain': domain }
        return render_to_response('history.html', variables)

теперь в шаблоне вы можете перебирать это как:

{% for dom in domain %}

name: {{ dom.name }}

{% for item in dom.domainposition_set %} 

     date: item.date

     position: item.position
{% endfor %}

{% endfor %}
0 голосов
/ 20 августа 2010

Поскольку у вас есть внешний ключ от DomainPosition до Domain, вы сможете получить набор всех позиций домена, которые ссылаются на конкретный домен dom, с помощью dom.domainposition_set.all().

You.затем вы можете построить свою таблицу, перебирая этот список позиций домена в вашем шаблоне.

...