如何将时间戳添加到ManyToMany记录

时间:2015-08-02 21:05:51

标签: python django django-models django-forms many-to-many

我有以下型号:

class Meeting(models.Model):
    meeting_title = models.CharField(default='', max_length=128, blank=True, null=True)
    meeting_time = models.TimeField(blank=False, null=False)
    meeting_date = models.DateField(blank=False, null=False) 
    meeting_visitors = models.ManyToManyField(Visitor, blank=True, default="")

以下表格:

class AddMeetingForm(forms.ModelForm):
    class Meta:
            model = Meeting
            fields = '__all__'

由于meeting_visitorsManyToMany字段,因此它可以包含一个或多个Visitor条记录。

此表格可在白天的不同时间更新。我想知道添加到会议中的每个Visitor的时间戳(即在现实世界中,当他们到达会议时)。

最简单/最有效的方法是什么?

我知道我可以通过timestamp获取模型实例已更新的meeting_updated = models.DateTimeField(auto_now_add =False, auto_now=True),但我想要meeting_visitors字段中每条记录的等效项。

1 个答案:

答案 0 :(得分:4)

您可以使用多对多字段中的through关键字轻松创建此关系

  

Django允许您指定将用于管理的模型   多对多的关系。然后你可以在上面添加额外的字段   中间模型。中间模型与   ManyToManyField使用through参数指向模型   将充当中间人。

因此,您可以这样使用它。

class Visitor(models.Model):
    name = models.CharField(max_length=30)

class Meeting(model.Model):
    title = models.CharField(max_length=30)
    time = models.TimeField(blank=False, null=False)
    date = models.DateField(blank=False, null=False) 
    attendance = models.ManyToManyField(Visitor, through='Attendant')


class Attendant(models.Model):
    visitors = models.ForeignKey(Visitor)
    meeting = models.ForeignKey(Meeting)
    created = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)