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

Django表单:隐藏字段中的外键

Django表单中的外键字段可以通过隐藏字段的方式来实现。以下是一个简单的示例:

首先,我们需要在模型中定义一个外键字段。例如,我们有两个模型:UserProfile,其中Profile模型有一个外键字段user,它关联到User模型。

代码语言:python
复制
from django.db import models

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

class Profile(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    bio = models.TextField()

接下来,我们需要在表单中隐藏外键字段。为此,我们可以使用ModelChoiceField字段,并将其widget设置为HiddenInput

代码语言:python
复制
from django import forms
from .models import Profile

class ProfileForm(forms.ModelForm):
    user = forms.ModelChoiceField(
        queryset=User.objects.all(),
        widget=forms.HiddenInput()
    )

    class Meta:
        model = Profile
        fields = ['user', 'bio']

在这个示例中,我们将user字段设置为ModelChoiceField,并将其widget设置为HiddenInput,这将在表单中隐藏该字段。然后,我们在Meta类中指定要包含的字段。

现在,当我们在视图中使用此表单时,外键字段将被隐藏,并且可以通过其他方式(例如通过视图函数中的请求对象)设置该字段的值。例如:

代码语言:python
复制
from django.shortcuts import render
from .forms import ProfileForm

def create_profile(request):
    if request.method == 'POST':
        form = ProfileForm(request.POST)
        if form.is_valid():
            # 设置外键字段的值
            form.instance.user = request.user
            # 保存表单
            form.save()
            return redirect('success')
    else:
        form = ProfileForm()
    return render(request, 'create_profile.html', {'form': form})

在这个示例中,我们在create_profile视图中使用ProfileForm。如果请求是POST请求,则表单将被填充,并在表单验证后保存。在这种情况下,我们将user字段设置为当前请求的用户,然后保存表单。如果请求是GET请求,则表单将为空。

这就是如何在Django表单中隐藏外键字段的方法。

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

相关·内容

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

和表关系 在MySQL,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用是InnoDB引擎,是支持约束存在使得ORM框架在处理表关系时候异常强大。...因此这里我们首先来介绍下Django使用。 类定义为class ForeignKey(to,on_delete,**options)。...因此在底层,Django为Article表添加了一个属性名_id字段(比如author字段名称是author_id),这个字段是一个,记录着对应作者主键。...即只要这条数据引用了那条数据,那么就不能删除外那条数据。 3.SET_NULL:设置为空。如果那条数据被删除了,那么在本条数据上就将这个字段设置为空。...如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果那条数据被删除了。那么将会获取SET函数值来作为这个值。

3.9K30

django在开发取消约束实现

# 在setting设置 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给关系传值...''' 两种方法 教室ClassRoom和教室编号ClassNumber 字段django类里名(room_number)在数据库名(room_number_id) '''      # 一.1...(数据库字段名字room_number_id)值,将相对应值直接赋值给该字段      class_number = ClassNumber.object.get("id=1").room_number...字段django类里名(room_number)在数据库名(room_number_id)      c.save() return HttpResponse("ojbk") 多对一: 类似一对一...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发取消约束就是小编分享给大家全部内容了,希望能给大家一个参考。

3.6K10

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

db_table = 'xxx'指定该类数据库表单名字。当然如果不指定也没关系,Django会自动默认按照一定规则生成数据模型对应数据库表名。...如两张表建立了一对一字段在A表,那么先往B表写数据就更合理。...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外设置反向查询字段名:正向找字段名,反向找related_name...例子:部门没有了,部门员工里部门字段改为未分组部门id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系多个 3)db_constraint...,将两张表设置为级联,并将反向查询字段名设置为detail 数据库脏数据介绍 数据库中常见并发操作所带来了一致性问题包括:丢失修改,不可重复读,读“脏”数据,幻读。

4.3K30

DjangoAutoField字段使用

Django是一个机智框架】 默认情况下Djang会为ORM定义每一张表加上一个自增ID列,并且用这个列来做主键;出于一个MySQL-DBA工作经历我觉得 Djanog还真是机智;这样么说主要是因为我遇到过许多主从延时问题...补充知识:Djangomodels下常用Field以及字段参数 一、常见FieldType数据库字段类型 1、AutoField:自增Field域,自动增加一个数据库字段类型,例如id字段就可以使用该数据类型...:删除关联数据: a、与之关联值设置为指定值,设置:models.SET(值) b、与之关联值设置为可执行对象返回值,设置:models.SET(可执行对象) 5、db_constraint:是否在数据库创建约束...,默认为True,db_constraint一般使用在建立数据表连接关系当中(例如创建),如果使用False,则是限制了表之间没有关联,达到了软连接效果 五、元信息 ORM对应类里面包含另一个Meta...https://docs.djangoproject.com/en/dev/ref/models/fields/ 以上这篇DjangoAutoField字段使用就是小编分享给大家全部内容了,希望能给大家一个参考

6.3K20

django模型中有关系表删除相关设置

0904自我总结 django模型中有关系表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...AuthorDetail表:作者删除详情删除,详情删除作者保留 2)作者找详情用 related_name(detail),详情找作者用 字段(author) 3)db_constraint...Book表(多一方):出版社删除书不动,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint...断开表关联,on_delete规定逻辑关联删除动作,models.DO_NOTHING关联无动作 三.以外字段关联 1)断关联,删除关联表记录,键值置空 db_constraint=False,...:出版社删除或书删除彼此不影响,但关系表一定级联删除 2)正向找 字段,反向找 字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表设置

3K20

Django 2.2文档系列】Model on_delete参数用法

场景 我们用DjangoModel时,有时候需要关联。关联时,参数:on_delete几个配置选项到底是干嘛呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束行为,在删除此条数据时,同事删除外关联对象。...比如:用户有一个关联是用户健康记录表,当用户删除时,配置了这个参数健康记录表中跟这个用户有关数据也会被删除。...当数据被删除时,被关联内容被设置为null。 models.SET_DEFAULT 将值设置为默认值。必须设置有默认值 。...如果后端数据库有强制关联操作,这是容易报错:IntegrityError,除非你在数据库手动添加了SQLON DELETE约束。

1.9K10

Django(ForeignKey)操作以及related_name作用

之前已经写过一篇关于Django文章,但是当时并没有介绍如何根据对数据操作,也就是如何通过主表查询子表或者通过子表查询主表信息 首先我定义了两个模型,一个是老师模型,一个是学生模型,...,并获取老师相关信息 返回一个teacher对象,接下来就是查询teacher相关联学生对象,在这里有一个需要注意点,django默认情况下每一个主表对象都有一个是属性,可以通过它查询到所有关于子表信息...migrate 从上图可以看到和之前_set操作效果是一样,这两个方法是相同,所以如果觉得比较麻烦的话,可以在定义主表时候,直接就给定义好名称使用related_name...上面的查询主要是通过主表查询子表信息 下面说一下如何通过子表查询主表相关信息,也就是查询一个学生所对应老师信息 首先需要先获取一个子表对象,那么就可以通过定义时候那个字段名获取关于主表信息了...比如我得到了一个student对象,然后我想要得到这个student对象对应主表teache信息的话,就使用 student.teacher 获取,其中这个teacher就是在子表定义字段

1.9K10

django序列化时使用真实值操作

展示: 一般情况下序列化得到内容只是id: ... { fields: { uat_date: "2015-07-25", statu: "CG", name: "慢赢优化",...方法: 我序列化是Content表,它含有一个关联是Module表,1对多 我要先序列化Module表,然后序列化Content表时候才可以使用到Module真实值 class ModuleManager...actual_key,要保证先序列化,如下依赖: class Content(models.Model): name = models.CharField(max_length=100) ......原生序列化serialize解析 在写接口时候,大家都离不开对query结果集序列化 嗯嗯嗯,一般我们都有DRF里面的序列化工具,但是django原生serialize你们有 用过吗??????...,这种方法并不常用 在有特定需要时候,使用这种django原生序列化,还是十分方便

1.8K10

django 模型计算字段实例

verbose_name='姓') given_name = models.CharField(max_length=20, verbose_name='名') def name(self): # 计算字段要显示在修改页面只能定义在只读字段...name.short_description = '全名' # 用于显示时名字 , 没有这个,字段标题将显示'name' readonly_fields = ('name',) admin.site.register...(Person, PersonAdmin) 补充知识:django如何在 search_fields 包含字段 在search_fields中加入一个名字是不能查询,要写成(键名__字段名...)形式. search_fields = ('attributename','goodsclass__cn') # goodsclass__cn 就可以搜索名字中有搜索词条目了, # 比如搜索手机分辨率...,而不是电脑分辨率,就可以搜索'手机 分辨率' 以上这篇django 模型计算字段实例就是小编分享给大家全部内容了,希望能给大家一个参考。

4.4K20

在 Laravel 动态隐藏 API 字段方法

在这个例子,让我们假设在用户列表,我们只想要所有用户名字,而在用户显示,我们只想隐藏电子邮件地址。 <?...UsersResource::make 将会返回 UsersResource 对象. 因此,我们应该揭开 hide 神秘面纱,它可以存储我们期望从响应移除. <?...* 删除隐藏 * * @param $array * @return array */ protected function filterFields($array) {...我不推荐过度重复去请求API资源,因为它很可能会把简单事情变得更加复杂,所以说在请求时候隐藏某些特定字段是更简单、更合理解决方案。...以上所述是小编给大家介绍在 Laravel 动态隐藏 API 字段方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家

5.4K31

django 2.x版本models.ForeignKey()说明介绍

第二个class创建一个名称为app_userinfos表 1、ForeignKey 表示设置健 2、to_field表示健关联主键 3、on_delete有多个选项 在django2.0后,...定义和一对一关系时候需要加on_delete选项,此参数为了避免两个表里数据不一致问题,不然会报错: TypeError: init() missing 1 required positional...SET_NULL:此值设置,会把设置为null,前提是允许为null。 SET_DEFAULT:此值设置,会把设置为默认值。 SET():此值设置,会调用外面的值,可以是一个函数。...当我们查询一个组有那些用户时候,就会用到当前健, 创建记录 并且,在class定义了foreignKey之后,group还不存在同时,user表也因为约束原因,不能被进行创建 删除记录 并且...2.x版本models.ForeignKey()说明介绍就是小编分享给大家全部内容了,希望能给大家一个参考。

1.1K20

laravel5.6约束示例

场景 如果现在有两张表,一张表是文章表articles,一张表是分类表categories,其中在文章表中有一个分类字段category_id,现在想在删除分类表某一分类时,该分类下所有文章也一起被删除...,那么这时候就可以用到外约束 具体用法如下: 给文章表添加约束 $table- unsignedInteger('category_id')- comment('文章所属分类|select');...$table- foreign('category_id')- references('id')- on('categories')- onDelete('cascade'); 其中需要注意是分类表categories...主键字段id与文章表articles字段category_id数据类型或者是数据长度要保持一致,因为作为主键id值是从1开始自增,所以在被其绑定字段数据类型就不能使用integer...,而要改用unsignedInteger 以上这篇laravel5.6约束示例就是小编分享给大家全部内容了,希望能给大家一个参考。

1.7K31

Django Model字段(field)各种选项说明

字段与选项 CharField() 字符字段 max_length = xxx or None # 必选项 blank = True 和 default = ” # 如果不是必填项,可以设置 unique...default = date.today # 需要导入包 from datetime import date DateTimeField:default = timezone.now # 需要导入包 from django.utils...可以设置 through = ‘intermediary model # 如果需要建立中间模型来搜集更多信息,可以设置 related_name = xxx # 便于反向查询 补充知识:django 使用...annotate定义字段后排序翻页重复问题 objs = A.objects.annotate(number=Sum(‘b__number’)).order_by(‘-number’) 此时对objs...(‘-number’, ‘id’) 以上这篇Django Model字段(field)各种选项说明就是小编分享给大家全部内容了,希望能给大家一个参考。

1.7K30
领券