我有以下型号:
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_visitors
是ManyToMany
字段,因此它可以包含一个或多个Visitor
条记录。
此表格可在白天的不同时间更新。我想知道添加到会议中的每个Visitor
的时间戳(即在现实世界中,当他们到达会议时)。
最简单/最有效的方法是什么?
我知道我可以通过timestamp
获取模型实例已更新的meeting_updated = models.DateTimeField(auto_now_add =False, auto_now=True)
,但我想要meeting_visitors
字段中每条记录的等效项。
答案 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)