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

Django:如何从model表单上的选择中获取外键ID?

在Django中,可以通过以下步骤从model表单上的选择中获取外键ID:

  1. 首先,在你的model中定义外键字段。例如,假设你有一个名为Book的model,其中包含一个外键字段author,指向Author模型:
代码语言:txt
复制
from django.db import models

class Author(models.Model):
    name = models.CharField(max_length=100)

class Book(models.Model):
    title = models.CharField(max_length=100)
    author = models.ForeignKey(Author, on_delete=models.CASCADE)
  1. 在你的视图函数中,当处理表单提交时,可以通过request.POST获取用户选择的外键ID。假设你的表单中有一个名为author的选择字段:
代码语言:txt
复制
from django.shortcuts import render
from .models import Book

def create_book(request):
    if request.method == 'POST':
        title = request.POST['title']
        author_id = request.POST['author']  # 获取用户选择的外键ID
        book = Book(title=title, author_id=author_id)
        book.save()
        # 其他处理逻辑...
    else:
        # 渲染表单页面...
        return render(request, 'create_book.html')

在上述代码中,request.POST['author']将返回用户选择的外键ID。

  1. 如果你想在模板中获取外键ID,可以使用Django模板语言的value_from_instance过滤器。假设你的模型实例为book,你可以通过以下方式获取外键ID:
代码语言:txt
复制
<select name="author">
  {% for author in authors %}
    <option value="{{ author.id }}" {% if book.author_id == author.id %}selected{% endif %}>{{ author.name }}</option>
  {% endfor %}
</select>

在上述代码中,author.id将返回外键ID,并使用selected属性将选中用户之前选择的选项。

总结起来,要从model表单上的选择中获取外键ID,你需要在model中定义外键字段,然后在视图函数中通过request.POST获取用户选择的外键ID,或者在模板中使用value_from_instance过滤器获取外键ID。

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

相关·内容

【Django 2.2文档系列】Model 外键中的on_delete参数用法

场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束的行为,在删除此条数据时,同事删除外键关联的对象。...提醒:级联删除不会调用model级行为,但是会为所有已删除对象发送pre_delete和 post_delete信号,有用Django的信号机制的场景,要考虑这个级联删除带来影响。...当数据被删除时,被关联的外键内容被设置为null。 models.SET_DEFAULT 将外键的值设置为默认值。外键必须设置有默认值 。...如果后端数据库有强制关联操作,这是容易报错:IntegrityError,除非你在数据库中手动添加了SQL的ON DELETE约束。

2K10

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

这么多种选择放在一起,如何分出高下?我想此时的场景下就两个标准: 1、相同的功能用最少的代码实现(代码少BUG也会少); 2、相对最易于理解,从而易于维护和扩展。...所以,基本表单的功能看BaseForm已经足够了。 2、从模型创建表单 django对于MVC中的C与M间的映射是非常体贴的,集中体现中Model模型中(比如模型的权限与用户认证)。...那么,一个模型代表着RDS中的一张表,模型的实例代表着关系数据库中的一行,而form如何与一行相对应呢?...#按照四条数据库记录的顺序依次的创建(调用save方法)、主键赋到下一条记录的外键中、下一次记录创建(save)           projectAddress = context['projectAddressForm...'].save()           #从项目表单中获取到模型,先把地址的id赋到外键上再保存           project = context['projectForm'].save(commit

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

    ', on_delete=models.CASCADE) 说明:mysql中,生成的外键列名称,会自动命名为:field_id,如上borrower field对应的mysql列为borrower_id...如果设置了该选项值,那么默认的表单组件将变为一个select box,而不是标准是text field,且将被限制从给定choice中选择choice。...删除被参照表的某条表记录,同时级联删除参照表中,同待删除记录存在外键关联关系的记录。 PROTECT 删除被参照表中的某条表记录,如果参照表中,存在与该记录有外键关系的记录,则不让删除。...SET_DEFAULT 删除被参照表的某条表记录,设置参照表中,同待删除记录存在外键关联的记录的外键列值为默认值。必须为外键列设置默认值。...SET() 删除被参照表的某条表记录,设置参照表中,同待删除记录存在外键关联关系的记录的外键列值为传递给SET()的参数值,如果传递给SET()的参数值是可调用对象,则设置为调用可调用对象获取的结果。

    2.2K20

    如何使用 Python 和 SQLAlchemy 结合外键映射来获取其他表中的数据

    在使用 Python 和 SQLAlchemy 时,结合外键映射可以让你在查询时轻松地获取其他表中的数据。...SQLAlchemy 提供了丰富的 ORM(对象关系映射)功能,可以让你通过定义外键关系来查询并获取关联的数据。下面我会演示如何设置外键关系,并通过 SQLAlchemy 查询获取其他表中的数据。...现在,我们希望从 Order 表中查询订单信息时,同时获取该订单所属客户的姓名和电子邮件地址。...2.3 添加另一个外键如果我们需要在 Order 表中添加另一个外键,例如 product_id 字段,并且希望获取该订单所属产品的信息,那么我们可以在 Order 类中定义一个新的关系属性,使用 relationship...总结结合外键映射,你可以通过 SQLAlchemy 轻松地获取不同表之间关联的数据。你可以使用:relationship:设置表之间的关系(如外键),并通过 ORM 获取关联的数据。

    14310

    Django项目知识点(四)

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

    1.6K30

    37.Django1.11.6文档

    实例化、处理和渲染表单 在Django 中渲染一个对象时,我们通常: 在视图中获得它(例如,从数据库中获取) 将它传递给模板的context 使用模板变量将它扩展为HTML 标记 除了几个关键点不同之外...当我们实例化表单时,我们可以选择让它为空还是预先填充它,例如使用: 来自一个保存后的模型实例的数据(例如用于编辑的管理表单) 我们从其它地方获得的数据 从前面一个HTML 表单提交过来的数据 获取HTML...选择验证后端 用户登录时,用户的ID和用于身份验证的后端保存在用户的会话中。 这允许相同的身份验证后端在将来的请求中获取用户的详细信息。 ...这是必需的。 InlineModelAdmin.fk_name 模型上的外键的名称。 在大多数情况下,这将自动处理,但如果同一父模型有多个外键,则必须显式指定fk_name。...覆盖此方法以编程方式确定最小内联表单数。 例如,这可以基于模型实例(作为关键字参数obj传递)。 使用具有两个或多个外键的模型与同一个父模型 有时可能有多个外键到同一个模型。

    24.4K80

    Django模型

    Django模型 Django的模型定义在models.py文件中。模型是MVT中的M,也相当于MVC中的M。 在Django中,模型必须继承自Model类。...外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...choices参数就是从我们定义的二元组(GENDER_CHOICES)中获取值。二元组的第一个值会储存在数据库中,而第二个值将只会用于在表单中显示。...设置外键的时候需要制定另一张表中关联的字段,但是在Django里并没有指定。...这是因为Django会默认指定另外一张表的id作为关联字段。如下图所示: 可以看到peopleinfo这张表中的外键名称是book_id

    1.9K20

    Django 3.1 官网学习路线

    字段还可以有各种可选参数;在本例中,我们将投票的默认值设置为 0。 最后,请注意使用外键定义了关系。这告诉 Django 每个选择都与一个问题相关。...按照惯例,Django 会将"_id"附加到外键字段名。(是的,你也可以重写这个。) 外键关系是通过外键约束来显式的。...不要担心可延期的部分;它告诉 PostgreSQL 在事务结束之前不要强制执行外键。...OK migrate 命令获取所有还没有应用的迁移(Django 跟踪哪些迁移是使用数据库中名为 django_migrations 的特殊表应用的),并在数据库上运行它们——本质上,就是将您对模型所做的更改与数据库中的模式同步...“添加选择”表单如下所示: 在该表单中,“Question”字段是一个选择框,包含数据库中的每个问题。Django 知道一个外键应该在管理中表示为一个框。在我们的例子中,目前只存在一个问题。

    8.2K10

    django_2

    dept 部门表:主表 emp 员工表:从表 两张中有级联关系 带主键的表是主表 带外键的表是从表 关联关系放在从表 (团员找班长--> 快) sql的优化 一对多模型关系: class Grade...根据属性的类型确定以下信息 ·当前选择的数据库支持字段的类型 ·渲染管理表单时使用的默认html控件 ·在管理站点最低限度的验证 ·django会为表增加自动增长的主键列,每个模型只能有一个主键列...models.CharField(max_length=16) s_grade = models.ForeignKey(Grade) 使用: 模型类名__属性名__比较运算符,实际上就是处理的数据库中的...join Grade ---g_name Student---》s_name s_grade(外键) gf = Student.objects.filter...根据属性的类型确定以下信息 ·当前选择的数据库支持字段的类型 ·渲染管理表单时使用的默认html控件 ·在管理站点最低限度的验证 ·django会为表增加自动增长的主键列,每个模型只能有一个主键列

    3.6K30

    Django源码学习-25-ContentType

    Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。...在django中,有一个记录了项目中所有model元数据的表,就是ContentType,表中一条记录对应着一个存在的model,所以可以通过一个ContentType表的id和一个具体表中的id找到任何记录...,及先通过ContenType表的id可以得到某个model,再通过model的id得到具体的对象。...通过model_class就可以获取对应的类。如果自定义model,如果有外键关联到这个ContentType上,就能找到对应的model名称。 ?...1.ContentType.model_class(): 获取当前ContentType类型所代表的模型类。

    67030

    06.Django基础五之django模型层(二)多表操作

    一 创建模型 表和表之间的关系     一对一、多对一、多对多 ,用book表和publish表自己来想想关系,想想里面的操作,加外键约束和不加外键约束的区别,一对一的外键约束是在一对多的约束上加上唯一约束...注意事项: 表的名称myapp_modelName,是根据 模型中的元数据自动生成的,也可以覆写为别的名称   id 字段是自动添加的 对于外键字段,Django 会在字段名上添加"_id" 来创建数据库中的列名...但是我们就不能使用ORM外键相关的方法了,所以我们单纯的将外键换成一个其他字段类型,只是单纯的存着另外一个关联表的主键值是不能使用ORM外键方法的。...例如,如果 Article model 中做一下更改:     那么接下来就会如我们看到这般: 在这里我们补充一点,因为你很快就要接触到了,那就是form表单里面的button按钮和form表单外面的button...我们可以直接从django提供的接口中获取数据库连接,然后像使用pymysql模块一样操作数据库。

    2.7K20

    Django学习-第七讲:django 中的常用字段、字段属性,外键和表关系、外键操作

    因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...以后通过article.author访问的时候,实际上是先通过author_id找到对应的数据,然后再提取User表中的这条数据,形成一个模型。...即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。 3.SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。...如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果外键的那条数据被删除了。...那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。

    4K30

    django 1.8 官方文档翻译:2-1-1 模型语法

    如果设置了choices ,默认的表单将是一个选择框而不是标准的文本框,而且这个选择框的选项就是choices 中的选项。...中介模型有一些限制: 中介模型必须有且只有一个外键到源模型(上面例子中的Group),或者你必须使用ManyToManyField.through_fields 显式指定Django 应该使用的外键。...如果你的模型中存在超个一个的外键,并且through_fields没有指定,将会触发一个无效的错误。 对目标模型的外键有相同的限制(上面例子中的 Person)。...对于通过中介模型与自己进行多对多关联的模型,允许存在到同一个模型的两个外键,但它们将被作为多对多关联关系的两个(不同的)方面。...Changed in Django 1.7: 在Django 1.6 及之前的版本中,中介模型禁止包含多于一个的外键。

    5K20

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

    常用字段 (1) AutoField 自增的整型字段,必填参数primary_key=True,则成为数据库的主键,无该字段时,django会自动创建主键id字段。...l 存储在数据库中的所有文件都是该文件的路径(相对于MEDIA_ROOT)。如果ImageField调用了,则mug_shot可以使用来获取摸板中图像的绝对路径。...默认表单格式为TextInput。 (18) TextField 文本字段。默认表单小部件是Textarea,如果指定max_length属性,将反映在Textarea自动生成的表单字段中。...SET_NULL:删除时把外键置为null,当null=True时才可以使用。 SET_DEFAULT:把外键置为默认值,必须要设置默认值时才可以使用。...(24) OneToOneField 一对一关系的关系,从概念上与带有unique=True的ForeignKey相似,但是在关系的另一侧(主表数据)直接返回单个对象。

    3.9K30

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

    现在先来试试重新排序表单上的字段。...在这个表单中,Question字段是一个select选择框,包含了当前数据库中所有的Question实例。Django在admin站点中,自动地将所有的外键关系展示为一个select框。...在我们的例子中,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。每一个包含外键关系的对象都会有这个绿色加号。...点击它,会弹出一个新增Question的表单,类似Question自己的添加表单。填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice的关联外键对象。...通俗讲就是,新建一个Question并作为当前Choice的外键。 但是,实话说,这种创建方式的效率不怎么样。

    3.6K60

    玩了下flask,很轻量级的一个web开发框架

    url 路由也是很方便 和django差不多,直接用表示变量就好,默认是字符串,可以使整形,浮点,uuid,path, 如果在装饰器上不设置methods的话默认是get提交方式 *** 路由重定向...,直接传递,然后在模板文件中用模板语言调用即可 模板中可以一样的用到切片操作,很方便 语法都是和python语法一样的,非常的友好 *** 过滤器也是和django的一样的 | 后面接着过滤器名称就好...(db.String(16),unique=True) # 定义字段,用户类型只能唯一 class User(db.Model): __tablename__=’users’ id=db.Column...(db.Integer,primary_key=True) name=db.Column(db.String(16),unique=True) # 用上面表的id来表示外键 role_id=db.Column...(db.Integer,db.ForeignKey(‘roles.id’)) # 外键 *** orm增删改查 *** db.session.commit() 提交 db.session.delete

    1.1K30

    从 Django 模型中根据类查找外键

    在 Django 中,如果你有一个模型类,并希望找出哪些其他模型定义了指向该模型的外键,可以使用 Django 的元选项 (Meta) 和 ForeignKey 的反向关系属性。...例如,在 Book 模型中,外键可能叫做 author_id, 而在 Article 模型中,外键可能叫做 author.我们希望有一个方法可以根据外键的类来检索外键对象,无论外键的名称是什么。...例如,我们希望有一个方法可以获取 Book 模型中指向 Author 模型的外键对象,无论这个外键的名称是什么。...该方法返回了指向 Author 模型的外键字段,并将其存储在 author_foreign_key 变量中。问题背景Foo 有很多可以从 Django 模型引用的外键,但我希望使用通用方法来获取对象。...代码示例下面的代码示例演示了如何使用 get_foo() 函数来获取指向 Foo 对象的外键:from django.core.exceptions import FieldDoesNotExistfrom

    8810

    Python面试题:Django Web框架基础与进阶

    一、基础问题概览Django架构与组件:MVC与MTV:解释Django的MTV(Model-Template-View)架构与传统MVC架构的区别。...数据库操作:ORM:描述Django ORM的基本使用,包括定义模型、执行CRUD操作、查询过滤等。数据库迁移:解释Django的数据库迁移机制,演示如何创建、应用、回滚迁移。...二、进阶问题概览中间件与信号:中间件:描述中间件的作用、生命周期及其在请求处理过程中的位置,编写自定义中间件示例。信号:解释Django信号机制,列举常用信号类型,演示如何发送、接收信号。...表单与验证:表单类:阐述Django表单类的定义、字段类型、验证规则、绑定数据、清洗数据等过程。自定义验证:演示如何为表单字段添加自定义验证方法,处理复杂验证逻辑。...规避:遵循数据库设计原则,合理使用外键、多对多关系、索引,避免数据冗余。模板过度嵌套与逻辑混杂:误区:在模板中编写过多业务逻辑,导致模板层次过深、可读性差。

    26010

    关于“Python”的核心知识点整理大全59

    下面来修改模型Topic,在其中添加一个关联到用户的外键。这样做后,我们必须对数据库 进行迁移。最后,我们必须对有些视图进行修改,使其只显示与当前登录的用户相关联的数据。 1....中添加了字段owner,它建 立到模型User的外键关系。...在3处,Django给我 们提供了两种选择:要么现在提供默认值,要么退出并在models.py中添加默认值。在4处,我们 选择了第一个选项,因此Django让我们输入默认值(见5)。...代码 Topic.objects.filter(owner=request.user)让Django只从数据库中获取owner属性为当前用户的 Topic对象。...= 'POST': # 初次请求,使用当前条目的内容填充表单 --snip-- 我们获取指定的条目以及与之相关联的主题,然后检查主题的所有者是否是当前登录的用 户,如果不是,就引发Http404

    14410

    如何使用 Django 更新模型字段(包括外键字段)

    本教程将详细介绍如何通过 Django 更新模型字段,重点讨论了解决外键字段更新的方法,特别是使用 attrs 方式的实现。1. 简介Django 中的模型是应用程序中管理数据的核心部分。...下面我们详细探讨这种更新方式:使用 attrs 方式更新外键字段在 Django 中,可以直接通过设置外键字段的方式来更新模型中的外键关联。...这种方式不需要每次都查询外键表(例如 Student 表)中的对象,而是直接使用外键的 ID 进行更新操作。...总结与实践建议在本教程中,我们深入探讨了如何使用 Django 更新模型字段,特别是处理外键字段更新的方法。...希望本教程能够帮助你理解和应用 Django 中模型字段更新的技巧,提升你在开发过程中的效率和数据管理能力。在实际应用中,根据具体情况选择合适的更新方法,以确保应用程序的稳定性和性能优化。6.

    28010
    领券