Ich habe zwei Modelle. Kampagne und Platzierung. Jedes Placement-Objekt bezieht sich nur auf ein Kampagnenobjekt. Ich möchte alle Campaign-Objekte mit allen verknüpften Placements auflisten.Listen Sie alle Objekte von zwei Modellen in einer Ansicht
Kampagne 1
- Platzierung # 1
- Platzierung # 2
Kampagne 2
- Platzierung # 3
- Platzierung # 4
...
Wie kann ich tun es mit einer Ansicht und einer Vorlage?
Kampagnenmodell:
class Campaign(models.Model):
ACTIVE = 1
INACTIVE = 0
STATUS_CHOICES = (
(ACTIVE, 'Active'),
(INACTIVE, 'Inactive'),
)
CPC = 'cpc'
CPM = 'cpm'
CPV = 'cpv'
status = models.IntegerField(default=1, choices=STATUS_CHOICES)
client_name = models.ForeignKey(Client, on_delete=models.CASCADE)
campaign_name = models.CharField(max_length=100)
start_date = models.DateField(default=datetime.date.today)
end_date = models.DateField(default=datetime.date.today)
def __str__(self):
name = str(self.client_name) + " - " + self.campaign_name
return name
Placement Modell:
class Placement(models.Model):
ACTIVE = 1
INACTIVE = 0
STATUS_CHOICES = (
(ACTIVE, 'Active'),
(INACTIVE, 'Inactive'),
)
CPC = 'cpc'
CPM = 'cpm'
CPV = 'cpv'
UNIT_CHOICES = (
(CPC, 'CPC'),
(CPM, 'CPM'),
(CPV, 'CPV'),
)
status = models.IntegerField(default=1, choices=STATUS_CHOICES)
campaign_name = models.ForeignKey(Campaign, on_delete=models.CASCADE)
publisher_name = models.ForeignKey(Publisher, on_delete=models.CASCADE)
start_date = models.DateField(default=datetime.date.today)
end_date = models.DateField(default=datetime.date.today)
unit_type = models.CharField(default='cpc', choices=UNIT_CHOICES, max_length=3)
units = models.IntegerField(default=0)
budget = models.IntegerField(default=0)
budget_spent = models.IntegerField(default=0)
units_delivered = models.IntegerField(default=0)
def __str__(self):
return str(self.publisher_name)
Danke das hat funktioniert! – TityBoi