In my application I need to check up on people's attendance and I want to know who hasn't attended two or more meetings. I have the following models:
class Talk(models.Model):
title = models.CharField(max_length=200, primary_key=True)
speaker = models.CharField(max_length=200)
date_of_talk = models.DateField('date_of_talk')
def __unicode__(self):
return self.title
class Member(models.Model):
name = models.CharField(max_length=200)
talks = models.ManyToManyField(Talk, through='Event_Attendance')
def __unicode__(self):
return self.name
class Event_Attendance(models.Model):
talk = models.ForeignKey('Talk')
membersAttended = models.ForeignKey('Member')
As you can see I keep track of all the members attending talks.
My thoughts on how to find the members that haven't attended was to get all the members then iterating through them to find out whether or not they are in the Event_Attendance
table. Is this the best approach or does Django have a method to already do this?