2013-07-07 6 views
6

ho le seguenti strutture modello:Django - Accesso tramite ManyToMany campo aggiuntivo nel modello

class Project(models.Model): 
    title  = models.CharField(max_length = 100) 
    publish  = models.BooleanField() 
    cover  = models.ForeignKey(GenericMedia, related_name='+') 
    media  = models.ManyToManyField(GenericMedia, through='AssocProjectMedia') 
    credits  = models.ManyToManyField(AssocTitleName) 

class GenericMedia(models.Model): 
    limit   = models.Q(model = 'Image') | models.Q(model = 'Other') 
    content_type = models.ForeignKey(ContentType, limit_choices_to = limit) 
    object_id  = models.PositiveIntegerField() 
    content_object = generic.GenericForeignKey('content_type', 'object_id') 

    def __unicode__(self): 
     return u"%s" % os.path.basename(self.content_object.url.name) 

    def instance(self): 
     return self.content_object.__class__.__name__ 


class AssocProjectMedia(models.Model): 
    project  = models.ForeignKey(Project) 
    media  = models.ForeignKey(GenericMedia) 

    position = models.PositiveSmallIntegerField() 
    grid_size = models.PositiveSmallIntegerField(null = True, blank = True) 

    class Meta: 
     ordering = ['position'] 

ho cercato per un po 'per ottenere i dati di posizione (include in AssocProjectMedia) nel mio modello con il seguente:

a mio avviso:

project = get_object_or_404(Project, slug=project_slug) 
    return render(request, 'projects/projects_details.html', {"project":project}) 

nel mio modello:

{% for media in project.media_set.all %} 
... 
{% endfor %} 

Ma questo non funziona, non appare nulla.

Se invece scrivo:

{% for media in project.media.all %} 
... 
{% endfor %} 

mi metterò i miei dati multimediali, ma non quella inclusa nel tramite del modello (AssocProjectMedia).

Se qualcuno ha un'idea su come farlo ...

risposta

13

Prova questo:

{% for assoc_media in project.assocprojectmedia_set.all %} 
    {{assoc_media.position}} 
    {# or whatever field #} 
{% endfor %} 
+2

Oh è il lavoro, grazie! È possibile modificare il related_name della relazione 'through'? –

+0

È possibile ottenere solo una riga in base a un filtro anziché a assocprojectmedia_set.all() nel modello? per esempio, vorrei ottenere la posizione dove project = xx, media = xx – Kevin