【问题标题】:How do I use queryset.update in a Django Admin action?如何在 Django 管理操作中使用 queryset.update?
【发布时间】:2021-11-16 08:03:23
【问题描述】:

我有一个 Django Admin 操作来更新模型中的值(包括外键)。代码是:

def staff_reset(self, request, queryset):
    updated=queryset.update(regstatus='registered', medicalform__medform_status='required', 
        staffmonitoringform__monitoring_status = 'required', staffreleaseform__release_status ='required',
        staffethics__ethics_status = 'required', staffethics__i_agree=False)
    self.message_user(request, ngettext(
        '%d staff registration was successfully reset.',
        '%d staff registrations were successfully reset.',
        updated,
        ) % updated, messages.SUCCESS)
staff_reset.short_description="Reset Staff Registrations"

我的订单模型:

class Order(models.Model):
    REGSTATUS = (
        ('registered', 'registered'),
        ('enrolled', 'enrolled'),
        ('holding', 'holding'),
        ('withdrawn', 'withdrawn'),
        ('waiting', 'waiting'),
        )
    FORMSTATUS = (
        ('required', 'required'),
        ('submitted', 'submitted'),
        )

    customer = models.ForeignKey(Customer, on_delete= models.CASCADE, null = True)
    training_registered = models.ForeignKey(TrainingInstance, on_delete= models.SET_NULL, blank = True, null = True)
    registration_date = models.DateTimeField(null=True,blank=True)

    releaseform = models.ForeignKey(ReleaseForm, on_delete= models.SET_NULL, blank = True, null = True)
    staffreleaseform = models.ForeignKey(StaffReleaseForm, on_delete= models.SET_NULL, blank = True, null = True)
    monitoringform = models.ForeignKey(MonitoringForm, on_delete= models.SET_NULL, blank = True, null = True)
    medicalform = models.ForeignKey(MedicalForm, on_delete= models.SET_NULL, blank = True, null = True)
    staffmonitoringform = models.ForeignKey(StaffMonitoringForm, on_delete= models.SET_NULL, blank = True, null = True)
    staffethics = models.ForeignKey(StaffEthicsForm, on_delete= models.SET_NULL, blank = True, null = True)

    regstatus = models.CharField(max_length=200, null=True, choices=REGSTATUS, default='registered')
    enrolment_note = models.TextField(max_length=1000, null=True,blank=True, default="please ensure that ALL THREE forms are submitted. Please note your place on the NWTA will not be offered until all the forms are submitted and processed.")

    staffcheck = models.ForeignKey(StaffCheck, on_delete= models.SET_NULL, blank = True, null = True)


    par_payment = models.ForeignKey(ParticipantPayment, on_delete= models.SET_NULL, blank = True, null = True)

    def __str__(self):
        return self.customer.username

MedicalForm 模型有一个名为 medform_status 的字段:

medform_status = models.CharField(max_length=200, null=True, choices=FORMSTATUS, default='required')

但我收到一条错误消息,提示“订单没有名为 'medicalform__medform_status' 的字段”。关于我是否可以将 queryset.update() 与外键一起使用的任何想法? 提前致谢。

【问题讨论】:

  • 你能分享你的模型吗?
  • 在这种情况下,必须为每个模型单独进行更新

标签: django django-models django-admin django-queryset


【解决方案1】:

在这种情况下,每个外键都需要像这样单独更新:

    updated = queryset.update(regstatus='registered')

    MedicalForm.objects.filter(
        pk__in=queryset.values('medicalform')
    ).update(medform_status='required')

    StaffMonitoringForm.objects.filter(
        pk__in=queryset.values('staffmonitoringform')
    ).update(monitoring_status='required')

    StaffReleaseForm.objects.filter(
        pk__in=queryset.values('staffreleaseform')
    ).update(release_status='required')

    StaffEthicsForm.objects.filter(
        pk__in=queryset.values('staffethics')
    ).update(ethics_status='required', i_agree=False)

【讨论】:

    猜你喜欢
    • 2021-08-03
    • 2017-05-04
    • 2013-09-01
    • 2020-03-30
    • 2016-04-18
    • 2014-04-17
    • 2021-04-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多