如何更新多个字段,包括django模型实例的相关字段?

时间:2013-05-15 16:28:16

标签: django django-models

我想知道,更新多个字段的标准方法是什么,其中包括django中模型实例的相关字段? ...

Class User(models.Model):
    id = models.CharField()
    name = models.CharField()
    dob = models.CharField()

Class Appointment(models.Model):
    user = models.ForeignKey(User)
    app_id = models.CharField()
    time = models.DateTimeField()
    status = models.CharField()

要更新约会模型中的多个字段,我可以这样做

dict ={
"app_id": "123",
"time": "2012-01-01 10:30",
"status": "Open"
}
Appointment.objects.filter(app_id=123).update(dict)

有没有办法更新相关模型? 如何更新约会模型和用户模型?
情况下:

dict ={
"name": "foo",
"app_id": "123",
"time": "2012-01-01 10:30",
"status": "Open"
}

1 个答案:

答案 0 :(得分:3)

为了清楚起见 - 那不是“继承”的意思。约会与用户有关,但不会从中继承。

查询集上的更新方法无法在单个调用中执行此操作。文档说:

  

更新的QuerySet的唯一限制是它只能更新模型主表中的列,而不能更新相关模型中的列。

https://docs.djangoproject.com/en/dev/ref/models/querysets/#update

如果你有app_id而没有别的,你可以写第二次更新电话:

User.objects.filter(appointment__app_id=123).update(name='foo')