创新互联Django4.0教程:Django4.0执行查询-一次修改多个对象

有时候,你想统一设置 ​QuerySet ​中的所有对象的某个字段。你可以通过 ​update()​ 达到目的。例如:

为迁西等地区用户提供了全套网页设计制作服务,及迁西网站建设行业解决方案。主营业务为网站建设、做网站、迁西网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

# Update all the headlines with pub_date in 2007.
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')

你仅能用此方法设置非关联字段和 ​ForeignKey ​字段。要修改非关联字段,需要用常量提供新值。要修改 ​ForeignKey ​字段,将新值置为目标模型的新实例。例如:

>>> b = Blog.objects.get(pk=1)

# Change every Entry so that it belongs to this Blog.
>>> Entry.objects.all().update(blog=b)

方法 ​update()​ 立刻被运行,并返回匹配查询调节的行数(若某些行早已是新值,则可能不等于实际匹配的行数)。更新 ​QuerySet ​的唯一限制即它只能操作一个数据表:该模型的主表。你可以基于关联字段进行筛选,但你只能更新模型主表中的列。例如:

>>> b = Blog.objects.get(pk=1)

# Update all the headlines belonging to this Blog.
>>> Entry.objects.filter(blog=b).update(headline='Everything is the same')

update()​ 方法是直接转为 SQL 语句的。这是一种用于直接更新的批量操作。它并不会调用模型的 ​save()​ 方法,也不会发出 ​pre_save​ 或 ​post_save​ 信号(这是调用 ​save()​ 的结果),或使用 ​auto_now​ 字段选项。若想保存 ​QuerySet ​中的每项,并确保调用了每个实例的 ​save()​ 方法,你并不需要任何特殊的函数来处理此问题。迭代它们,并调用它们的 ​save()​ 方法:

for item in my_queryset:
    item.save()

调用更新方法时也能使用 ​F​ 表达式 基于同一模型另一个字段的值更新某个字段。这在基于计数器的当前值增加其值时特别有用。例如,要增加博客中每个条目 ​pingback ​的计数:

>>> Entry.objects.all().update(number_of_pingbacks=F('number_of_pingbacks') + 1)

然而,与过滤器中的 ​F()对象和排除字句不同,你不能在更新方法中使用 ​F()​ 对象的同时使用 ​join​——你只能引用被更新模型的内部字段。若你试着在使用 ​join ​字句时使用 ​F()​ 对象,会抛出一个 ​FieldError()​:

# This will raise a FieldError
>>> Entry.objects.update(headline=F('blog__name'))

网页标题:创新互联Django4.0教程:Django4.0执行查询-一次修改多个对象
本文网址:http://www.mswzjz.cn/qtweb/news11/81561.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能