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 ...
Oh è il lavoro, grazie! È possibile modificare il related_name della relazione 'through'? –
È 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