Django" update_or_create" API:如何通过创建或更新来过滤对象?

时间:2016-06-22 15:41:00

标签: python django django-queryset django-filter

因此,我使用Django update_or_create API来构建表单数据。它工作得很好......但是,一旦构建,我需要一种方法来检查实际更新的配置文件或它们是否是第一次创建的?

只是一个例子:

    for people in peoples:
        people, updated = People.objects.update_or_create(
            id=people.person_id,
            defaults={
                'first_name': people.first_name,
            }
        )

过滤查询集:

   people = People.objects.filter(
        id__in=whatever,
   )

但是,现在,我试图通过创建或更新来过滤查询集...但是没有看到它的API(例如,各种各样的适应者)

所以,我想做点什么:

updated = Person.objects.filter(updated=True, created_for_first_time=False)

and then I can write something like

if updated:
   do this
else:
   do this

基本上,我只想检查个人资料是否第一次更新或创建。

2 个答案:

答案 0 :(得分:6)

正如您在问题中所示,update_or_create方法返回一个元组(obj, created),其中obj位于对象中,created是一个布尔值,显示是否为新对象已创建。

您可以检查布尔字段的值,并创建一个列表来存储新创建的对象的ID

new_objects = []
for people in peoples:
    obj, created = People.objects.update_or_create(...)
    if created:
        new_objects.append(obj.id)

然后您可以使用该列表进行过滤:

new_people = People.objects.filter(id__in=new_objects)
existing_people = People.objects.exclude(id__in=new_objects)

答案 1 :(得分:2)

致电update_or_create时:

person, created = People.objects.update_or_create(...)
如果记录是刚创建的,则created返回值将为True,如果是已更新的现有记录,则为False。如果您需要对这些信息采取行动,最好在此处进行操作,同时您可以访问它。

如果您以后需要这样做,我能想到的唯一方法是设计一个支持它的模式,即有create_datelast_modify_date字段,如果这两个字段相等,你知道记录自创建以来就没有被修改过。