update()

如果一个查询集是一个列表对象, 需要更新该列表对象里所有的单个数据集的数据,可以使用update()方法,而不须遍历整个查询集对象一个个逐一进行修改

obj_list = UserInfo.objects.all()

obj_list.update(money="10000000") # 不需要再调用save()进行手动的保存

这样就把obj_list 里所包含的所有的数据集的money字段进行更新为 "10000000"了

注意update()方法不适用于当个查询集对象,单个查询集对象通过类似 query_set_obj.money =  "100000000", query_set_obj.save() 方式进行操作

get_or_update()

查询或者创建, 如果存在就是返回查询到对象,如果不存在就进行创建

一个通过给出的kwargs 来查询对象的便捷方法(如果你的模型中的所有字段都有默认值,可以为空),需要的话创建一个对象。

返回一个由(object, created)组成的元组,元组中的object是一个查询到的或者是被创建的对象, created是一个表示是否创建了新的对象的布尔值。

obj,created=Person.objects.get_or_create(first_name='John',last_name='Lennon',defaults={'birthday': date(1940, 10, 9)})

当然,也可以通过在视图进行一个逻辑的判断,来确定查询不到数据时就进行创建,但是如果使用get_or_create() 往往会更加便捷

05-11 15:36
查看更多