首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

来自queryset的Django模型实例在保存时不更新()

的原因是,Django的QuerySet对象是一个延迟查询的对象,它会在需要时才从数据库中获取数据。当我们从数据库中获取一个对象的QuerySet,并对其进行修改后保存,如果我们使用的是QuerySet对象的update()方法或者直接对QuerySet对象的某个字段进行修改并保存,那么这个操作不会立即影响数据库中的数据。

这是因为QuerySet对象是一个查询结果集合,它并不是一个具体的模型实例对象。当我们使用QuerySet对象的update()方法或者直接对QuerySet对象的某个字段进行修改后保存时,Django会直接将修改的操作翻译成SQL语句,并发送给数据库执行。这样的操作绕过了Django的模型层,不会触发模型对象的保存机制,也就不会更新数据库中的数据。

如果我们希望在保存时更新来自QuerySet的Django模型实例,可以通过以下两种方式实现:

  1. 使用模型实例对象的save()方法进行保存:
  2. 使用模型实例对象的save()方法进行保存:
  3. 这样,Django会触发模型实例对象的保存机制,将修改后的数据更新到数据库中。
  4. 使用update()方法进行更新,但需要注意更新的字段不能是模型实例的属性:
  5. 使用update()方法进行更新,但需要注意更新的字段不能是模型实例的属性:
  6. 这种方式会直接将修改操作翻译成SQL语句发送给数据库执行,不会触发模型实例对象的保存机制。

需要注意的是,如果我们需要同时更新多个模型实例对象的数据,使用update()方法可以更高效地执行批量更新操作;而如果只需要更新单个模型实例对象的数据,使用save()方法更为合适。

推荐的腾讯云相关产品:腾讯云数据库MySQL、腾讯云云服务器、腾讯云对象存储COS。

腾讯云数据库MySQL产品介绍链接地址:https://cloud.tencent.com/product/cdb 腾讯云云服务器产品介绍链接地址:https://cloud.tencent.com/product/cvm 腾讯云对象存储COS产品介绍链接地址:https://cloud.tencent.com/product/cos

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

完整的 Django 零基础教程|初学者指南 - 第 4 部分 转自:维托尔·弗雷塔斯

这里 Django 创建了一个新对象,因为Board 实例没有id 。...要更新一个值,我们可以这样做: board.description = 'Django discussion board.' board.save() 每个 Django 模型都有一个特殊的属性;我们称之为模型管理器...基本上,它是来自数据库的对象列表。我们可以看到我们有两个对象,但是我们只能读取Board object 。那是因为我们还没有 __str__在Board 模型中定义方法。...models操作总结 下面是我们在本节中学习的方法和操作的摘要,使用Board 模型作为参考。...大写的Board 指的是类,小写的board 指的是Board 模型类的一个实例(或对象): Operation 代码示例 创建对象而不保存 board = Board() 保存对象(创建或更新) board.save

80220

Django-官网查询部分翻译(1.11版本文档)-QuerySet-字段查找-06

django(ORM)中,数据库与 python 对象的映射关系十分形象,一个表模型类(class)即代表一张表,实例化出一个对象即代表一条数据记录 创建一个对象(一条数据记录) 在 django...,直到你调用了 .save() 方法( .save() 没有返回值) 保存修改的表对象 想要保存一个已经改动过的对象,调用 .save() 方法即可(更新一条记录) 下面是一个 Blog 表模型类的实例化对象...,下面的语句是更新一个 Entry 模型类实例化出来的 entry 对象的 blog 属性(请确保下面用到的 Entry 和 Blog 的实例化对象已经存在在数据库中,这样我们的语句才能将它们查出来)...不!其实它只执行了一次,只在执行最后一行 print(q) 的时候执行了数据库操作。...=False) 过滤字段 .none() 创建空的 QuerySet 调用 .none() 方法会创建一个空的 QuerySet ,里面不包含任何数据对象,并且在取值时也不会执行任何数据库操作(是 EmptyQuerySet

2.9K20
  • django 1.8 官方文档翻译: 2-2-1 执行查询

    python对象,django使用一种直观的方式:一个模型类代表数据库的一个表,一个模型的实例代表数据库表中的一条特定的记录。...假设一个Blog的实例b5已经被保存在数据库中,这个例子更改了它的名字,并且在数据库中更新它的记录: >>> b5.name = 'New name' >>> b5.save() 上面的代码在背后执行了...更新非关系字段时,传入的值应该是一个常量。更新 ForeignKey 字段时,传入的值应该是你想关联的那个类的某个实例。...在 QuerySet 进行更新时,唯一的限制就是一次只能更新一个数据表,就是当前 model 的主表。所以不要尝试更新关联表和与此类似的操作,因为这是不可能运行的。...在调用 update 时可以使用 F() 对象 来把某个字段的值更新为另一个字段的值。

    4.4K20

    Django的Manager和QuerySet

    models本身没有什么需要多说的,Django 使用了一套直观的系统:一个模型类代表一张数据表,一个模型类的实例代表数据库表中的一行记录。 模型类的save方法可以插入,更新,删除数据。...在Django中,模型的Manager提供了接口,它赋予了 Django 模型操作数据库的能力。默认情况下,Django 为每个模型类添加了一个名为 objects 的 Manager。...people = models.Manager() # 自定义名为people的管理器 使用这个实例模型时, Person.objects 会产生一个 AttributeError 异常,而 Person.people.all...有关如何自定义Manager,在Django管理器中有详细说明。 QuerySet 一个 QuerySet 代表来自数据库中对象的一个集合。它可以有 0 个,1 个或者多个 filters。...在Django的文档中,明确的告诉了开发者,什么时候QuerySet被执行。因为这影响到SQL执行效率。

    1.1K30

    Django 学习笔记之模型(下)

    题图:by thefolkpr0ject from Instagram 上篇文章讲解了 Django 如何创建模型,本文将继续讲解如何对模型进行增删改查操作。...1 前言 当我们建立好数据模型,Django 会自动为我们生成一套数据库接口相关的接口。这套接口称为 QuerySet API。为什么叫 QuerySet ?...因为从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet。 为了方便理解,我继续使用上篇文章的例子。另外方便我们在打印对象信息时,能得到对象的信息。所以我们需要对之前的代码做下修改。...但是这里比较特殊,QuerySet 对象的 id 是从 1 开始的,所以 [:3] 表示 [1:3], 返回 id 为 1, 2, 3 的对象。 另外,这种切片操作时可以节约内存的。...4 更新数据 更新数据操作,一般是在查询数据后才执行。

    66930

    Django之QuerySet详解

    可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...如果不传递任何值给values_list(),它将返回模型中的所有字段,以在模型中定义的顺序。 常见的情况是获取某个模型实例的特定字段值。...tzinfo参数定义在截取之前将数据时间转换到的时区。 11. none() 调用none()将创建一个不返回任何对象的查询集,并且在访问结果时不会执行任何查询。...Entry.objects.defer("body").only("headline", "body") 当对具有延迟字段的实例调用save()时,仅保存加载的字段。...如果查找不到对象,get_or_create()将会实例化并保存一个新的对象,返回一个由新的对象以及True组成的元组。

    2.4K20

    Django学习之旅(六)

    每个模型都有一些类变量,在模型中每个类变量都代表了数据库中的一个字段。 每个字段通过 Field 类的一个实例表示 —— 例如字符字段 CharField 和日期字段 DateTimeField 。...这种方法告诉 Django,每个字段中保存着什么类型的数据。更多字段以及含义可以阅读 Django 官方文档。 4 创建表 打开终端,切换目录到 manage.py 所在目录。...在 Django 中,一个模型类对应一个数据库的表。因此,一个模型类的实例就表示表中的一条数据。为了输出的数据一目了然,我们需要对上面的 model 进行优化。 ?...当我们在 model.py 对这两个模型类修改完成之后,我们需要通知数据库:“我模型已经修改了,你数据库也要更新呀”。 只需要执行上步的两行命令即可 ?...而一旦我们建立好数据模型,Django 会自动为我们生成一套数据库抽象的API。这样就大大方便我们创建、检索、更新和删除对象。 假如现在有个需求,我们需要查询数据库中所有的作者并打印出作者的姓名。

    1.4K30

    37.Django1.11.6文档

    而这,正是代理继承要做的:为原始模型创建一个代理 。 你可以创建,删除,更新代理 model 的实例,而且所有的数据都可以像使用原始 model 一样被保存。...在模型实例不包含数据的情况下,在模板中对它做处理很少有什么用处。 但是渲染一个未填充的表单却非常有意义 —— 我们希望用户去填充它。 所以当我们在视图中处理模型实例时,我们一般从数据库中获取它。...当我们实例化表单时,我们可以选择让它为空还是预先填充它,例如使用: 来自一个保存后的模型实例的数据(例如用于编辑的管理表单) 我们从其它地方获得的数据 从前面一个HTML 表单提交过来的数据 获取HTML...这个方法根据表单绑定的数据创建并保存数据库对象。 ModelForm的子类可以接受现有的模型实例作为关键字参数instance;如果提供此功能,则save()将更新该实例。 ...使用commit=False 的另外一个副作用是在模型具有多对多关系的时候。 如果模型具有多对多关系而且当你保存表单时指定commit=False,Django 不会立即为多对多关系保存表单数据。

    24.4K80

    05.Django基础五之django模型层(一)单表操作

    创建名为book的app,在book下的models.py中创建模型: from django.db import models # Create your models here....时django 会在相应的 app 的migration文件夹下面生成 一个python脚本文件 在执行 python manager.py migrte 时 django才会生成数据库表,...model的实例化对象,而是一个可迭代的字典序列,只要是返回的queryset类型,就可以继续链式调用queryset类型的其他的查找方法,其他方法也是一样的。...,在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。...查询价格在100到200之间的所有书籍名称及其价格 5 查询所有人民出版社出版的书籍的价格(从高到低排序,去重)   关于django连接mysql的时指定严格模式的配置 DATABASES = {

    3K10

    Django源码学习-11-base.py

    Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。...base.py 保存视图的抽象类,TemplateView和RedirectView,及工具类TemplateResponseMixin的代码; create_update.py 基于函数的通用视图;...表示没有数据时显示空列表;否则将会产生一个404错误。 queryset 产生数据的queryset实例或"类queryset"数据列表。 model 关联的模型类。...paginated_by 分页的每页数据项数。默认不起用分页。 contextobjectname 保存到context中的对象名称。默认是$(model)_list。...方法 get_queryset 获取用于数据显示的列表对象。可以是类queryset对象。 queryset属性。未提供queryset属性时,返回model的默认管理器。

    1.2K30

    django 1.8 官方文档翻译: 2-5-6 多数据库

    每当一个查询需要知道使用哪一个数据库时,它将调用主路由,并提供一个模型和一个Hint (可选)。Django 然后依次测试每个路由直至找到一个数据库的建议。...例如,若要保存一个对象到legacy_users 数据库,你应该使用: >>> my_object.save(using='legacy_users') 如果你不指定using,save()方法将保存到路由分配的默认数据库中...将对象从一个数据库移动到另一个数据库 如果你已经保存一个实例到一个数据库中,你可能很想使用save(using=...) 来迁移该实例到一个新的数据库中。...当保存在statement 2中发生时,p已经具有一个主键,Django 将尝试在新的数据库上使用该主键。...然而,如果p 的主键在second数据库上已经在使用second 数据库中的已经存在的对象将在p保存时被覆盖。 你可以用两种方法避免这种情况。首先,你可以清除实例的主键。

    1.5K20

    Django——model基础

    在更新多对多的第三张表时,可以直接用以下方法 book_obj.authors.set(*[装有对象id的列表]) 此操作包含了两步clear+add 有时候字段获取的较多,但是需要更新的表里没有那么多字段...,此时需要删除一些字段,但是我们又需要用到这些字段的值时,可以用pop,即达到了删除的效果,也可以拿到对应的删除对象,保存下来进行其他操作 关键点:book_obj.authors是什么?  ...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。 ?...在“插入和更新数据”小节中,我们有提到模型的save()方法,这个方法会更新一行里的所有列。 而某些情况下,我们只需要更新行里的某几列。...在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。例如: ?

    1.1K100

    Django Admin后台管理:高效开发与实践

    查看模型列表:登录后,可以看到注册的所有模型的列表。 创建新记录:点击模型名称,进入编辑页面,填写字段后点击保存创建新记录。...认证后端:Django允许定义多个认证后端,用于验证用户凭据。 权限和授权:Django的权限系统基于对象,允许为每个对象实例设置权限。...组管理:组是用户的集合,可以为组分配权限,从而简化权限管理。 权限管理:权限分为两种,即对象权限和模型权限。模型权限适用于整个模型,而对象权限适用于模型的特定实例。...3.4 高级权限控制 对象权限:Django允许为模型的每个实例设置权限,这可以通过编写自定义权限类来实现。...链式调用:QuerySet支持链式调用,可以在一个语句中执行多个查询操作。 惰性执行:QuerySet是惰性执行的,这意味着它们在真正需要数据时才会执行查询。

    26010

    【Django】Django ORM 学习笔记

    同时 ORM 避免了不规范、冗余、风格不统一的 SQL 语句,可以避免很多人为的 bug,方便编码风格的统一和后期维护。...将数据库表和对象模型关联,我们只需针对相关的对象模型进行编码,无须考虑对象模型和数据库表之间的转化,大大提高了程序的开发效率。 方便数据库的迁移。...当需要迁移到新的数据库时,不需要修改对象模型,只需要修改数据库的配置。...对象和关系之间并不是完美映射 一般来说 ORM 足以满足我们的需求,如果对性能要求特别高或者查询十分复杂,可以考虑使用原生 SQL 和 ORM 共用的方式 Django ORM 在 Django 框架中集成了...当首次对 QuerySet 的所有实例进行求值时,会将查询结果保存到 QuerySet 的缓冲中。当再访问该 QuerySet 时,会直接从缓冲中取数据。

    2.2K20

    django 1.8 官方文档翻译: 2-5-1 管理器 (初稿)

    自定义管理器 在一个特定的模型中,你可以通过继承管理器类来构建一个自定义的管理器,以及实例化你的自定义管理器。...添加额外的管理器方法 为你的模型添加表级(table-level)功能时,采用添加额外的管理器方法是更好的处理方式。如果要添加行级功能--就是说该功能只对某个模型的实例对象起作用。...使用管理器访问关联对象 默认情况下,在访问相关对象时(例如choice.poll),Django 并不使用相关对象的默认管理器,而是使用一个”朴素”管理器类的实例来访问。...在整个这一节中,我们将那种由 Django 为你创建的管理器称之为 “自动管理器”,既有因为没有管理器而被 Django 自动添加的默认管理器, 也包括在访问关联模型时使用的临时管理器。...你也不应该在模型中使用这个属性之后,在类上改变它。这是因为在模型类被创建时,这个属性值马上就会被处理,而且随后不会再读取这个属性值。

    98120

    Django内置的通用类视图CBV及示例

    属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...(self.object) context_object_name:self.object也将存储在get_context_object_name()返回的名称中,该名称默认为模型的小写名称. 3....显示用于编辑现有对象的表单的视图,重新显示具有验证错误信息的视图,并且保存对象.这里使用从对象模型自动生成的表单(除非手动制定表单类)....实例 1、创建django工程,创建名为crud的app,此处略过 2、 修改models.py class employee(models.Model): id = models.IntegerField...context_object_name = 'employee_detail' #指定获取的模型列表数据保存的变量名。这个变量会被传递给模板。

    3.2K10

    Django学习之八:forms组件【对

    form 的实例,可以是空,也可以提前填充数据。归纳总结form实例化数据主要来自三个方面: 来自model instance 来自其它数据源 来自用户提交的表单数据。...所以,在实例化modelform时,instance参数除了会影响save()的行为,还会影响初始化参数initail的效果。...比如说form.save()可以保存或者更新form数据到数据库中。这里研究研究。...对于绑定了对象的方式,如果提供了数据且提供了instance实例,这是update这个实例对象。对于普通模式在ORM操作时出现了主键等冲突,就会save()操作报错。...通过modelform的save操作对应的model对象,关更新操作在实例化modelform时必须带上instance参数指明是更新的哪个model 对象数据,不然会编程新增,失去了想要修改操作的意图

    2.2K30

    Django之ORM数据库

    5.2  ORM表模型 表(模型)的创建: 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名。...在“插入和更新数据”小节中,我们有提到模型的save()方法,这个方法会更新一行里的所有列。 而某些情况下,我们只需要更新行里的某几列。...是具有cache的 当你遍历queryset时,所有匹配的记录会从数据库获取,然后转换成Django的model。...当queryset非常巨大时,cache会成为问题 处理成千上万的记录时,将它们一次装入内存是很浪费的。...所以使 #用iterator()的时候要当心,确保你的代码在操作一个大的queryset时没有重复执行查询 总结: queryset的cache是用于减少程序对数据库的查询,在通常的使用下会保证只有在需要的时候才会查询数据库

    2.6K10

    【Django】 开发:数据库操作和后台管理

    作用: 通常是对数据库中的字段值在不获取的情况下进行操作 用于类属性 (字段) 之间的比较。...F F('列名') 说明: 一个 F () 对象代表了一个 model 的字段的值 F 对象通常是对数据库中的字段值在不加载到内存中的情况下直接在数据库服务器端进行操作 示例 1 更新 Book...中的游标cursor对数据库进行 增删改查 操作 在 Django 中跨过模型类直接操作数据库 使用步骤: 导入 cursor 所在的包 Django 中的游标 cursor 定义在 django.db.connection...(设置完成后需要立马更新同步数据库) 2. verbose_name = '单数名' - 给模型对象的一个易于理解的名称(单数),用于显示在/admin管理界面中...', wife.author.name) 反向查询 通过反向关联属性查询 反向关联属性为实例对象.引用类名(小写),如作家的反向引用为作家对象.wife 当反向引用不存在时,则会触发异常 # 通过 author.wife

    4.1K40
    领券