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

如何将选择框的值作为外键传递(Django)

在Django中,可以通过使用外键字段来将选择框的值作为外键传递。以下是实现这一功能的步骤:

  1. 首先,在数据库模型中定义两个相关的模型,一个是包含选择框的模型,另一个是包含外键的模型。例如,我们有一个模型叫做Choice,其中包含一个选择框字段choice_value,还有一个模型叫做ForeignKeyModel,其中包含一个外键字段foreign_key
代码语言:txt
复制
from django.db import models

class Choice(models.Model):
    choice_value = models.CharField(max_length=100)

class ForeignKeyModel(models.Model):
    foreign_key = models.ForeignKey(Choice, on_delete=models.CASCADE)
  1. 接下来,在视图函数中处理表单提交的数据。首先,获取选择框的值,然后创建一个新的ForeignKeyModel对象,并将选择框的值作为外键赋值给foreign_key字段。
代码语言:txt
复制
from django.shortcuts import render
from .models import Choice, ForeignKeyModel

def my_view(request):
    if request.method == 'POST':
        choice_value = request.POST.get('choice_value')
        choice = Choice.objects.get(choice_value=choice_value)
        foreign_key_model = ForeignKeyModel.objects.create(foreign_key=choice)
        # 其他处理逻辑...
    else:
        # 渲染包含选择框的表单页面
        choices = Choice.objects.all()
        return render(request, 'my_template.html', {'choices': choices})
  1. 最后,在模板中渲染选择框,并将选择框的值作为外键传递给视图函数。
代码语言:txt
复制
<form method="post" action="{% url 'my_view' %}">
  {% csrf_token %}
  <select name="choice_value">
    {% for choice in choices %}
      <option value="{{ choice.choice_value }}">{{ choice.choice_value }}</option>
    {% endfor %}
  </select>
  <button type="submit">提交</button>
</form>

这样,当用户选择一个值并提交表单时,选择框的值将作为外键传递给视图函数,并在数据库中创建一个新的ForeignKeyModel对象,其中包含了选择框的值作为外键的关联。

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

相关·内容

Django 3.1 官网学习路线

如果您想更改服务器的端口,请将其作为命令行参数传递。...字段还可以有各种可选参数;在本例中,我们将投票的默认值设置为 0。 最后,请注意使用外键定义了关系。这告诉 Django 每个选择都与一个问题相关。...按照惯例,Django 会将"_id"附加到外键字段名。(是的,你也可以重写这个。) 外键关系是通过外键约束来显式的。...不要担心可延期的部分;它告诉 PostgreSQL 在事务结束之前不要强制执行外键。...“添加选择”表单如下所示: 在该表单中,“Question”字段是一个选择框,包含数据库中的每个问题。Django 知道一个外键应该在管理中表示为一个框。在我们的例子中,目前只存在一个问题。

8.2K10

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

场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束的行为,在删除此条数据时,同事删除外键关联的对象。...比如:用户的有一个外键关联的是用户的健康记录表,当用户删除时,配置了这个参数的健康记录表中跟这个用户有关的数据也会被删除。...当数据被删除时,被关联的外键内容被设置为null。 models.SET_DEFAULT 将外键的值设置为默认值。外键必须设置有默认值 。...models.SET()将SET()设置的值作为外键的值 ,如果传递了callable,则调用它的结果。 DO_NOTHING不采取行动。

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

    因为Django在处理字符串相关的Field的时候,即使这个Field的null=False,如果你没有给这个Field传递任何值,那么Django也会使用一个空的字符串""来作为默认值存储进去。...因此这里我们首先来介绍下外键在Django中的使用。 类定义为class ForeignKey(to,on_delete,**options)。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...4.SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。...5.SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。

    4K30

    Django项目知识点(三)

    ,也可另立主键并将“一”和“多”两表的主键作为关联表的外键; 多对多的表,则必须设中间关联表,关联表设独立主键,并引入两个“多”头的表的主键作为关联表的外键。...PROTECT:此值设置,是会报完整性错误。 SET_NULL:此值设置,会把外键设置为null,前提是允许为null。 SET_DEFAULT:此值设置,会把设置为外键的默认值。...一对多:当一张表中创建一行数据时,有一个单选的下拉框(可以被重复选择) 一个学院信息表有多个学生的信息表 再比如文章和作者之间的关系。一个文章只能由一个作者编写,但是一个作者可以写多篇文章。...在这里插入图片描述 如果没有学生,没有课程来报名上学干嘛,所以是多对一,多个学生合成一张报名表 注意:外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错...一般使用CASCADE 表示级联删除 也就是有一个数据其中一个表删了,管聊的表就会删除,想下如果有个学生不读了,删掉了所有学生报名表中的数据,它绑的外键的学生,课程,是不是先把它删了,这就是级联删除,如果设置了

    1.9K30

    Django管理后台技巧分享之实例关系的搜索,autocomplete_fields字段使用

    我希望在文章选择主题的时候可以输入关键字来搜过滤,这样可以减少可选项。基于这个需求,我又重新去看了一下Django关于admin的教程,终于找到了方法,现在分享一下。...问题现象 首先来看一下这个问题的现象,其实这个在Django的模型设计里面非常常见,就是当模型之间有关联的时候,给一个模型实例选择关联模型实例的时候,如果对方数量很多,会导致查找非常麻烦。...模型,这里设置autocomplete_fields字段的值为['question'],表示的意思是当模型Choice的实例在选择Question实例的是可以进行搜索,而搜索的规则就是Question的管理里面定义的...['name', 'subject__name'] @admin.register(Article) class ArticleAdmin(admin.ModelAdmin): # 可以给外键的选择增加搜索...,前提是外键的管理模型必须设置search_fields作为搜索条件 autocomplete_fields = ['topic'] 看一下效果: 这里已经出现了搜索框,可以通过搜索条件来过滤选项

    65820

    35.Django2.0文档

    它有一个或多个作者(和作者是多对多的关联关系[many-to-many]), 只有一个出版商(和出版商是一对多的关联关系[one-to-many],也被称作外          键[foreign key...以下示例演示如何将所有Publisher的country字段值由’U.S.A’更改为’USA’: ? update()方法会返回一个整型数值,表示受影响的记录条数。...如果你想选择多项,你必须还要按下Ctrl键。 虽然管理工具因此添加了注释(help_text),但是当它有几百个选项时,它依然显得笨拙。 更好的办法是使用 filter_horizontal。...默认地,管理工具使用`` 下拉框`` 来展现`` 外键`` 字段。但是,正如`` 多对多字段`` 那样,有时候你不想忍受因装载并显示这些选项而产生的大量开销。...解决这个问题的办法是使用`` raw_id_fields`` 选项。它是一个包含外键字段名称的元组,它包含的字段将被展现成`` 文本框`` ,而不再是`` 下拉框`` 。

    11.3K100

    后端框架学习-Django

    参数=值&参数=值"\> + form表单中的method为get GET请求方法中,如果有数据需要传递给服务器,通常会使用查询字符串传递。...models.PROTECT:保护删除,等同于mysql默认的RESTRICT SET_NULL:保留关联数据,设置为NULL SET_DEFAULT:将外键设置为默认值。...创建一对一数据 无外键的模型类,和之前相同 有外键的模型类: wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例...)) wife = Wife.objects.create(name=’王夫人’,author_id = 1(类属性字段绑值)) 一对一查询 正向查询:从外键查对象 反向查询:从对象查外键 调用反向属性查询到关联的一方...无外键的模型类,和之前相同 有外键的模型类: 类似上面 wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例)

    9.6K40

    Django数据库查询优化与AJAX

    第三范式(3NF):属性不依赖于其他非主键属性,属性直接依赖于主键(冗余性) 不同的属性之间不能有传递关系,也就是每一个属性的数据不能相互影响。...如: res = models.Book.objects.all()#只有当我们使用res时才会执行数据库查询的操作 all、only与defer all 拿到自己的所有的属性,但是没有与其他表建立外键的属性...这样做的好处:跨表查询也不需要重复走数据库,减轻数据库压力。select_related()括号内放多个外键字段,逗号隔开,会将多个外键字段关联的表与当前表拼成一张大表。...,特点:按步骤查询多张表,然后将查询结果封装到对象中,给用户的感觉好像还是连表操作,括号内支持传多个外键字段,每放一个外键字段就会多走一条SQL语句,多查一张表。...先添加普通的键值 MyFormData.append('username','ylpb'); // 添加了一组普通的简直对,append后面第一个参数是键,第二个参数是值

    2.4K20

    python基础菜鸟教程_菜鸟课程好还是文都好

    windows键+R打开搜索,输入cmd,进入到windows命令行页面,输入: pip install Django 当看到提示suceessful后,表示下载成功。...第二步,在Pycharm中新建Django项目。 在Pycharm左上角的菜单栏中,依次点击:File–>new project–>Django。在Location那一栏中可以选择项目存放的位置。...之后表示传递的参数,这里传递了p1和p2两个参数。 通过这样的方式传递参数,就不会出现因为正则匹配错误而导致的问题了。在Django中,此类参数的解析是通过request.GET.get方法获取的。...request.FILES 包含所有上传文件的类字典对象 request.GET.get( name ) 拿到GET请求里name的值,如果某个键对应有多个值,则不能直接用get取值,需要用getlist...一个绝对的或相对的URL,将原封不动的作为重定向的位置。

    1.7K10

    django orm 重点大全

    1.最简单的跨表,查询外键表中符合主表条件的记录列表 #用户类型表 class User_typ(models.Model): name=models.CharField(max_length=...(对象列表) obj=User.objects.filter(type__name='普通用户') 2.最简单的多表联查,查询外键表中符合主表的主表的条件的记录列表 #主表aa class aa(models.Model...2.orm字段必须要知道的一些属性 (0)null 如果为True,Django 将用NULL 来在数据库中存储空值。...(4)unique 如果该值设置为 True, 这个数据字段的值在整张表中必须是唯一的 (5)choices 由二元组组成的一个可迭代对象(例如,列表或元组),用来给字段提供选择项。...如果设置了choices , 默认的表单将是一个选择框而不是标准的文本框,而且这个选择框的选项就是choices 中的选项。

    79740

    Django之路由层

    一对多外键字段创建的时候同步到数据中表字段会自动加_id后缀,如果我们手动加了_id orm也会在给我们加一次,所以我们这里不要加_id """ # 书跟作者是多对多的关系外键字段建在任意一方都可以...,建议建在查询频率高的一方 一对多外键字段创建的时候同步到数据中表字段会自动加_id后缀,如果我们手动加了_id orm也会在给我们加一次,所以我们这里不要加_id 多对多关系,django orm会自动帮我们创建书籍和作者的第三张关系表...,在做路由分发的时候可以给每一个app创建一个名称空间,这样反向解析的时候就会选择去对应的名称空间去查找。...,就是起名字的时候直接把app的名字直接加上作为前缀就可以了,如:app01_rep。...3.9Django1.x和2.x的版本的路由层区别 1.Django2.x中默认的url通过path接收,path的第一个输入值不是正则表达式,里面写的是什么就按什么匹配。

    1.4K21

    【云+社区年度正文】Django从入门到精通No.2----模型

    help_text: 字段的提示信息 choices:显示选择框的内容,用不变动的数据放在内存中以避免跨表操作 verbose_name: 显示的字段名称 error_messages:自定义错误信息...1.多对一 因为是关联关系,所以我们必须指定两个类来进行相互操作,这里涉及到一个外键的操作,即ForeignKey字段,而且外键要定义在多的一方。...db_constraint=True # 是否在数据库中创建外键约束 parent_link=False # 在Admin中是否显示关联数据 2.多对多 多对多的表...,必须设中间关联表,关联表设独立主键,并引入两个“多”头的表的主键作为关联表的外键。...=None # 自定义第三张表时,使用字段用于指定关系表中那些字段做多对多关系表 db_constraint=True # 是否在数据库中创建外键约束

    2.1K00

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

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

    3.6K60

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

    ,redirect 和django一样,不过是reverse换成了url_for了,url_for 直接指向需要的url函数名就好了 *** return redirect(url_for(‘python...*** 以上是规范的请求方法,当然你可以选择无视,不遵守 *** 需要用到模板文件的话可以用 *** render_template(‘index.html’,a=a) {{a}} 传递参数也非常的简单...,直接传递,然后在模板文件中用模板语言调用即可 模板中可以一样的用到切片操作,很方便 语法都是和python语法一样的,非常的友好 *** 过滤器也是和django的一样的 | 后面接着过滤器名称就好...*** {{form.username}} 直接调用到这个控件框 {{form.username.label}} # 调用上面的控件命名 挺简单的, *** 数据库模型ORM映射 这里叫做...来表示外键 role_id=db.Column(db.Integer,db.ForeignKey(‘roles.id’)) # 外键 *** orm增删改查 *** db.session.commit

    1.1K30

    django 1.8 官方文档翻译: 3-5-2 使用Django输出PDF

    例如,Django在kusports.com上用来为那些参加March Madness比赛的人,生成自定义的,便于打印的 NCAA 锦标赛晋级表作为PDF文件。...这样就强制让浏览器弹出对话框来提示或者确认,如果机器上设置了默认值要如何处理文档。如果你去掉了'attachment;',无论什么程序或控件被设置为用于处理PDF,浏览器都会使用它。...response作为第一个参数。...复杂的PDF 如果你使用ReportLab创建复杂的PDF文档,考虑使用io库作为你PDF文件的临时保存地点。这个库提供了一个类似于文件的对象接口,非常实用。...在Django中使用它的方法和这篇文章所阐述的相同。 Pisa XHTML2PDF是另一个PDF生成库。Pisa自带了如何将 Pisa 集成到 Django的例子。

    1K40

    Django 学习笔记之模型高级用法(上)

    2.1 ForeignKey 1) on_delete 在 Django 2.0 中,设置外键时需要添加一个 on_delete选项。外键本身涉及到两个表的数据,况且外键在数据库中是有约束行为。...SET_NULL: 置空模式,删除的时候,外键字段被设置为空,前提就是`blank=True, null=True`,定义该字段的时候,允许为空。...SET_DEFAULT: 置默认值,删除的时候,外键字段设置为默认值,所以定义外键的时候注意加上一个默认值。 SET(): 自定义对应的实体的值。...2)limit_choices_to 该参数用于限制外键所能关联的对象,只能用于 Django 的 ModelForm(Django的表单模块)和 admin 后台,对其它场合无限制功能。...4) related_name 用于关联对象反向引用模型的名称。主要用于反向查询,即外键源模型实例通过管理器返回第一个模型的所有实例。

    2K30
    领券