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() 往往会更加便捷