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

如何在Django表单集中更新多个实例的外键

在Django表单集中更新多个实例的外键,可以通过以下步骤实现:

  1. 首先,确保你已经定义了相关的模型和表单。假设你有两个模型:ParentChild,其中Child模型有一个外键字段指向Parent模型。
  2. 创建一个继承自forms.ModelForm的表单类,用于更新Child模型的外键。在表单类中,定义一个字段来表示外键的更新。
代码语言:txt
复制
from django import forms
from .models import Child

class ChildForm(forms.ModelForm):
    parent = forms.ModelChoiceField(queryset=Parent.objects.all())

    class Meta:
        model = Child
        fields = ['parent']
  1. 在视图函数中,使用表单集来处理多个实例的更新。首先,获取需要更新的Child实例的查询集,并将其传递给表单集。然后,使用POST请求来处理表单数据,并验证表单数据的有效性。
代码语言:txt
复制
from django.shortcuts import render
from .forms import ChildForm

def update_children(request):
    children = Child.objects.all()
    formset = ChildFormSet(queryset=children)

    if request.method == 'POST':
        formset = ChildFormSet(request.POST, queryset=children)
        if formset.is_valid():
            formset.save()
            # 更新成功后的操作

    return render(request, 'update_children.html', {'formset': formset})
  1. 在模板中,使用表单集来渲染表单字段,并为每个实例显示一个表单。
代码语言:txt
复制
<!-- update_children.html -->
<form method="post">
  {% csrf_token %}
  {{ formset.management_form }}
  {% for form in formset %}
    {{ form.as_table }}
  {% endfor %}
  <input type="submit" value="保存">
</form>

这样,你就可以在Django表单集中更新多个实例的外键了。在这个例子中,我们使用了ModelChoiceField来表示外键字段,它会显示一个下拉列表供选择相关的Parent实例。当提交表单时,通过调用formset.save()来保存更新后的数据。

推荐的腾讯云相关产品:腾讯云云服务器(https://cloud.tencent.com/product/cvm)和腾讯云数据库MySQL版(https://cloud.tencent.com/product/cdb_mysql)可以提供稳定可靠的云计算基础设施和数据库服务,以支持Django应用的部署和数据存储。

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

相关·内容

Django——ContentType(与多个表建立关系)及ContentType-signals使用

可以看到,我们通过model_class就可以获取对应类。也就是说,今后,我们如果自己定义model如果有关联到這个ContentType上,我们就能找到对应model名称。...对于新鲜事这个功能来说就是使用GenericRelation来产生一个特殊,它不像models.ForeignKey那样,必须指定一个Model来作为它指向对象。...怎么从这张操作记录表中得到相应操作model呢,这就得用到fields.GenericForeignKey,它是一个特殊,可以指向任何Model实例,在这里就可以通过这个字段来指向类似Post...是再给上面的表增加一个,然后重新修改数据库么?显然是不能,一旦数据库被创建了,我们几乎很少再去修改数据,如果再给其添加额外字段,无疑会带来不必要麻烦。...总之,如果一个表与其他表有多个关系,我们可以通过ContentType来解决这种关联。

4.3K20

django中ModelForm多表单组合解决方案

所以,基本表单功能看BaseForm已经足够了。 2、从模型创建表单 django对于MVC中C与M间映射是非常体贴集中体现中Model模型中(比如模型权限与用户认证)。...ContextMixin在context上下文中加入’view’元素,值为self实例。 ProcessFormView在GET请求上渲染表单,在POST请求上解析form到表单实例。...所以,从模型创建出表单ModelForm,配合上通用视图后,威力巨大!! 4、多个ModelForm在一个form里提交 终于可以回到本文主题了。...此时是不能save,因为project和address对应数据库记录还没有创建,所以commit传为False           contract = form.save(commit=False...#按照四条数据库记录顺序依次创建(调用save方法)、主键赋到下一条记录中、下一次记录创建(save)           projectAddress = context['projectAddressForm

3.3K20

Django model 层之Models与Mysql数据库小结

choice 一个由多个2元组,组成可迭代对象(tuple、list)。...删除被参照表某条表记录,同时级联删除参照表中,同待删除记录存在外关联关系记录。 PROTECT 删除被参照表中某条表记录,如果参照表中,存在与该记录有关系记录,则不让删除。...SET_NULL 删除被参照表某条表记录,设置参照表中,同待删除记录存在外关联记录列值为null。当且仅当设置了null=True选项时可用。...SET_DEFAULT 删除被参照表某条表记录,设置参照表中,同待删除记录存在外关联记录列值为默认值。必须为列设置默认值。...SET() 删除被参照表某条表记录,设置参照表中,同待删除记录存在外关联关系记录列值为传递给SET()参数值,如果传递给SET()参数值是可调用对象,则设置为调用可调用对象获取结果。

2.2K20

django 字段类型_access数据库类型是

参数: auto_now:每次修改保存修改为当前日期时间,对于“最后修改” 时间戳有用。在使用Model.save()保存时有效,使用QuerySet.update() 时不会自动更新。...默认表单格式为TextInput。 (18) TextField 文本字段。默认表单小部件是Textarea,如果指定max_length属性,将反映在Textarea自动生成表单字段中。...: from django.db import models class Car(models.Model): manufacturer = models.ForeignKey('Manufacturer...SET_NULL:删除时把置为null,当null=True时才可以使用。 SET_DEFAULT:把置为默认值,必须要设置默认值时才可以使用。...发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

3.8K30

django_2

dept 部门表:主表 emp 员工表:从表 两张中有级联关系 带主键表是主表 带表是从表 关联关系放在从表 (团员找班长--> 快) sql优化 一对多模型关系: class Grade...Django有两种过滤器用于筛选记录: filter:返回符合筛选条件数据集 exclude :返回不符合筛选条件数据集 链式调用: 多个filter和exclude可以连接在一起查询 Person.objects.filter...,查询集可以有多个过滤器。...:每个查询集都包含一个缓存,来最小化对数据库访问 在新建查询集中,缓存首次为空,第一次对查询集求值,会发生数据缓存,django会将查询出来数据做 一个缓存,并返回查询结果,以后查询直接使用查询集缓存...join Grade ---g_name Student---》s_name s_grade() gf = Student.objects.filter

3.6K30

Django中基表创建、字段属性简介、脏数据概念、子序列化

db_table = 'xxx'指定该类数据库表单名字。当然如果不指定也没关系,Django会自动默认按照一定规则生成数据模型对应数据库表名。...两张表建立了一对一字段,在A表,那么先往B表写数据就更合理。...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外中设置反向查询字段名:正向找字段名,反向找related_name...例子:部门没有了,部门员工里部门字段改为未分组部门id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系中多个 3)db_constraint...3)如果关联表有多个字段时,需要设置子序列化字段many=True。 4)子序列化是单向操作,因为作为子系列类必须写在上方,所以不能产生逆方向子序列化。

4.3K30

Django数据库查询优化与AJAX

: res = models.Book.objects.all()#只有当我们使用res时才会执行数据库查询操作 all、only与defer all 拿到自己所有的属性,但是没有与其他表建立属性...这样做好处:跨表查询也不需要重复走数据库,减轻数据库压力。select_related()括号内放多个字段,逗号隔开,会将多个字段关联表与当前表拼成一张大表。...,特点:按步骤查询多张表,然后将查询结果封装到对象中,给用户感觉好像还是连表操作,括号内支持传多个字段,每放一个字段就会多走一条SQL语句,多查一张表。...AJAX 不是新编程语言,而是一种使用现有标准新方法。 AJAX 最大优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。...Django内置serializers模块 前端想拿到通过orm查到一个个对象,(数据库里一条条记录),后端想把直接实例化出来对象发送给前端,这时候就需要用到Django给我们提供序列法方式(

2.3K20

django

- 于Python字典不同,QueryDict类型对象用来处理同一个带有多个情况 - 方法get(): 根据获取值、只能获取一个值、如果一个同时拥有多个值...,则获取最后一个值 - 方法getlist(): 根据获取值,将值以列表返回,可以获取一个多个值 - GET属性 - QueryDict类型对象...后面 - 参数格式是键值对,key1=value1 - 多个参数之间,使用&连接,key1=value1&key2=value2 - 是开发人员定下来...- 表单中控件必须有name属性,name为,value为值 - CheckBox存在一多值问题 - 是开发人员定下来,值是可变 - 手动编写视图...- 实验目的 - 利用Django快捷函数手动编写视图处理函数 - 编写过程中理解视图运行原理 - 分析: - Django把所有请求信息封装

1.6K10

Django——model基础

myapp_modelName,是根据 模型中元数据自动生成,也可以覆写为别的名称   2、id 字段是自动添加 3、对于字段,Django 会在字段名上添加"_id" 来创建数据库中列名...6、字段 ForeignKey 有一个 null=True 设置(它允许接受空值 NULL),你可以赋给它空值 None 。...@163.com") 字段 ?...如果我们要对两个字段值做比较,那该怎么做呢? Django 提供 F() 来做这样比较。F() 实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段值。 ?...在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 行为,换句话说,删除一个对象时也会删除与它相关联对象。例如: ?

1.1K100

Django 3.1 官网学习路线

也就是说,您需要自动生成一些建立 Django 项目的代码——Django 实例设置集合,包括数据库配置、特定于 Django 选项和特定于应用程序设置。...字段还可以有各种可选参数;在本例中,我们将投票默认值设置为 0。 最后,请注意使用定义了关系。这告诉 Django 每个选择都与一个问题相关。...按照惯例,Django 会将"_id"附加到外字段名。(是的,你也可以重写这个。) 关系是通过约束来显式。...不要担心可延期部分;它告诉 PostgreSQL 在事务结束之前不要强制执行。...“添加选择”表单如下所示: 在该表单中,“Question”字段是一个选择框,包含数据库中每个问题。Django 知道一个应该在管理中表示为一个框。在我们例子中,目前只存在一个问题。

8.1K10

djangoRequest-7

QueryDict 在django HttpRequest 对象中,属性 GET 和 POST 得到都是 django.http.QueryDict 所创建实例,这是django自定义一个类似字典类...在Python字典中,一个只能有一个值,当一个赋值多次时候,只会保留最后一个值。而在 HttpRequest 对象中,一个往往有多个值。...而 QueryDict 就可以用来处理一个多个情况。 (1)....如果key 具有多个值,以列表形式返回 key 所有值。当key 不存在时返回一个空列表,设置了默认值则返回默认值。 3. 查询字符串 在url中格式 ?...非表单类型数据django无法自动解析,需要通过 request.body 获取原始请求体数据,然后自己根据数据类型解析。

1.2K30

Django 1.10中文文档-第一个应用Part7-自定义管理站点

并且在字段数据很多时,还可以将表单分割成多个字段集合: # polls/admin.py from django.contrib import admin from .models import Question...在这个表单中,Question字段是一个select选择框,包含了当前数据库中所有的Question实例Django在admin站点中,自动地将所有的关系展示为一个select框。...在我们例子中,目前只有一个question对象存在。 请注意图中绿色加号,它连接到Question模型。每一个包含关系对象都会有这个绿色加号。...点击它,会弹出一个新增Question表单,类似Question自己添加表单。填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice关联对象。...通俗讲就是,新建一个Question并作为当前Choice。 但是,实话说,这种创建方式效率不怎么样。

3.6K60

Django项目知识点(四)

json键值对,而不是列表 request.body就是form表单数据 Queryset Django ORM用到三个类:Manager、QuerySet、Model。...QuerySet实例 就是从数据库根据自己要求拿数据 连数据都那不出来,写啥视图 所以在编写queryset必须用django shell 调试 在model中,Django通过给Model增加一个objects...file_url','file_name','title','desc','image_url').filter(is_delete= False) select_related() 如果我要拿这个模型通过绑定另外一个模型...这样就可以引用模型字段值并使用它们执行数据库操作,而无需实际将它们从数据库中拉出到Python内存中 说白了就是我从数据库拿东西,但是有些需要字段没有,要通过绑定appmodel拿。...但是名称又是app__字段来命名,这样我要改名称,而且拿第一次model,放在python内存中,再拿通过绑定另一个model,又要执行第一次步骤,那个效率就不行了,干嘛我不一起拿,所以会用annotate

1.5K30

Django 之视图篇

一个标准Python字典,包含所有的cookie,和值都为字符串 session: 一个即可读又可写类似于字典对象,表示当前会话, 只有当Django启用会话支持时才可用 详细内容见"状态保持...、POST都是QueryDict类型对象 与python字典不同,QueryDict类型对象用来处理同一个带有多个情况 方法get(): 根据获取值 只能获取一个值 如果一个同时拥有多个值...,获取最后一个值 方法getlist(): 根据获取值 将值以列表返回,可以获取一个多个值 GET属性 QueryDict类型对象def v12_get(request): rst...后面 参数格式是键值对,即key1 = value1 多个参数之间,使用&相连,key1=value1&key2=value2 是开发人员定下来,值是可变 案例/views/v12_get POST...属性 QueryDict类型对象 包含post请求方式所有参数 与form表单控件对应 表单中控件必须有name属性, name为, value为值 checkbbox存在一多值问题 是开发人员定下来

1.1K87

django 1.8 官方文档翻译: 5-1-1 使用表单

相反,GET 组合提交数据为一个字符串,然后使用它来生成一个URL。这个URL 将包含数据发送地址以及数据和值。...现在你还需要一个对应/your-name/ URL 视图,它在请求中找到正确/值对,然后处理它们。 这是一个非常简单表单。...如果你想禁用这个行为,请设置form 标签novalidate 属性,或者指定一个不同字段,TextInput。...可重用表单模板 如果你网站在多个地方对表单使用相同渲染逻辑,你可以保存表单循环到一个单独模板中来减少重复,然后在其它模板中使用include 标签来重用它: # In your form template...更深入主题 这里只是基础,表单还可以完成更多工作: 表单集 在表单集中使用初始化数据 限制表单最大数目 表单验证 验证表单集中表单数目 处理表单排序和删除 添加额外字段到表单中 在视图和模板中视图表单

4.2K20

Django相关知识点回顾

7.3.1post表单提交数据 # 演示获取post表单提交数据 # /form/ # flask: request.form # django: requst.POST -> QueryDict类对象...class Meta: db_table = '' 定义属性: # 表中外字段名格式: hbook = models.ForeignKey('BookInfo...() # 由多查1 多对象.属性 例:hero.hbook 2.通过模型类进行关联查询 # 查图书(一) 一类.objects.get|filter(多类名__字段__条件=值) 例:books =...BookInfo.objects.filter(heroinfo__hcomment__contains='八') # 查英雄(多) 多类.objects.filter(属性__字段__条件=值)...例:查询id大于3图书数量 BookInfo.objects.filter(id__gt=3).count() exists:判断查询集中是否有数据 两大特性 惰性查询: 只有在使用查询集中数据时才会进行数据库真正查询操作

10K51

Django实战篇-论坛注册视图

在前两节中,完成了论坛模型层创建和表单 forms 创建。 在模型层中用到字段类型,有整型,字符串型,时间型还有就是关联。...Django基础篇-模型基础 ① 在论坛注册中,需要创建注册函数; Django 自带了登录和注销视图类。...因为登录是需要传递数据,所以为 POST 请求,接下来就是实例化注册验证表单 SignUpForm(),将 request.POST 写入,是为了将前端传来数据转成 form 表单。...经过 form.is_valid() 字段验证,完成 form 表单中所填字段是否为注册表单SignUpForm() 对应字段类型和字段要求。...② 注册表单验证 SignUpForm() from django import forms from django.contrib.auth.forms import UserCreationForm

79720
领券