Django запрос данных из дочерней модели в родительскую
Я создаю приложение, в котором я хочу показать весь список членов определенного комитета в моем шаблоне, но также я хочу показать статус того, заплатили ли они в этом месяце или нет. Теперь я совсем запутался, поскольку нет связи между таблицей Member и деталью Payment. Я могу получить список людей, которые заплатили, из таблицы детализации платежей, но я хочу показать весь список членов комитета и затем показать статус рядом с ними.
class Members(models.Model ):
user = models.ForeignKey(Users,verbose_name='User Id', on_delete=models.CASCADE)
com = models.ForeignKey(Committees, on_delete=models.CASCADE,verbose_name='Committee Name')
mem_status = models.CharField( max_length=20,choices=MEMBER_STATUS, verbose_name='Member Status')
mem_note = models.TextField(null=True, blank=True)
class PaymentDetails(models.Model):
mem = models.ForeignKey(Members,on_delete=models.CASCADE,verbose_name='Memeber Phone no')
com = models.ForeignKey(Committees, on_delete=models.CASCADE,verbose_name='Committee Name')
payment_month = models.DateField(default=datetime.now())
payment_amount_debit = models.IntegerField(null=True,blank=True)
payment_amount_credit = models.IntegerField(null=True,blank=True)
payment_status = models.CharField(max_length=16, choices=PAYMENT_DETAILS_CHOICES)
Вы можете сделать обратную связь, так как django автоматически создает связь на другой стороне:
views.py:
def your_view(request):
members = Members.objects.all().select_related()
members_context = [member.paymentdetails_set.values("payment_month", "payment_status") for member in members]
return render(request, 'your_template', {'members': members_context})
your_template_tag.py:
from django.template.defaulttags import register
@register.filter
def get_item(dictionary, key):
return dictionary.get(key)
your_template.html:
{% for member in members %}
<p> Payment Month: {{ member|get_item:"payment_month" }}</p>
<p> Payment Status: {{ member|get_item:"payment_status" }}</p>
{% endfor %}