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 %}
Вернуться на верх