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

过滤django中的两个外键关系

在Django中过滤两个外键关系可以通过使用双下划线(__)来实现。双下划线用于在查询中指定关联模型的字段。

假设有两个模型A和B,A模型有一个外键关联到B模型,而B模型有一个外键关联到C模型。现在我们想要过滤A模型中关联到C模型的某个字段的值为特定值的记录。

可以使用以下代码来实现:

代码语言:python
代码运行次数:0
复制
from django.db.models import F

A.objects.filter(b__c__field=value)

其中,A是模型A的名称,b是A模型中关联到B模型的字段名,c是B模型中关联到C模型的字段名,field是C模型中要过滤的字段名,value是要过滤的特定值。

这样就可以过滤出A模型中关联到C模型的某个字段的值为特定值的记录。

推荐的腾讯云相关产品和产品介绍链接地址:

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

相关·内容

Django(15)和表关系

大家好,又见面了,我是你们朋友全栈君。 删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样操作。可以通过on_delete来指定。...可以指定类型如下: CASCADE:级联操作。如果对应那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了那条数据,那么就不能删除外那条数据。...那么将会获取SET函数值来作为这个值。SET函数可以接收一个可以调用对象(比如函数或者方法),如果是可以调用对象,那么会将这个对象调用后结果作为值返回回去。...注意:以上这些选项只是Django级别的,数据级别依旧是RESTRICT! 表关系 表之间关系都是通过来进行关联。而表之间关系,无非就是三种关系:一对一、一对多、多对多等。...这个中间表分别定义了两个,引用到article和tag两张表主键。

2.1K40

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

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

4K30
  • 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...两者区别 models.SET关联表内容删了,关联相关内容不会删除 models.CASCAD关联表内容删了,关联相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系...:出版社删除或书删除彼此不影响,但关系表一定级联删除 2)正向找 字段,反向找 字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表设置

    3K20

    django在开发取消约束实现

    # 在setting设置 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给关系传值...,删除外关系 反查: 在表关系里 related_name = ‘反查name’,自己不设置,django也会默认设置为class小写名字+_set , ex: book_set....一对一关系赋值: class ModelStudy(View): ''' ClassRoom和ClassNumber是一对一关系,给传值 ''' def get(self, request):...(数据库字段名字room_number_id)值,将相对应值直接赋值给该字段      class_number = ClassNumber.object.get("id=1").room_number...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发取消约束就是小编分享给大家全部内容了,希望能给大家一个参考。

    3.7K10

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

    可以看到,我们通过model_class就可以获取对应类。也就是说,今后,我们如果自己定义model如果有关联到這个ContentType上,我们就能找到对应model名称。...对于新鲜事这个功能来说就是使用GenericRelation来产生一个特殊,它不像models.ForeignKey那样,必须指定一个Model来作为它指向对象。...怎么从这张操作记录表得到相应操作model呢,这就得用到fields.GenericForeignKey,它是一个特殊,可以指向任何Model实例,在这里就可以通过这个字段来指向类似Post...date = models.DateTimeField(verbose_name="答题日期", auto_now_add=True)   但是,如果我有另外一个需求,也需要与SurveryRecord建立关系...总之,如果一个表与其他表有多个关系,我们可以通过ContentType来解决这种关联。

    4.4K20

    mysql-三种关系

    介绍 因为有foreign key约束,使得两张表形成了三种了关系: 多对一 多对多 一对一 重点理解如果找出两张表之间关系 分析步骤: #1、先站在左表角度去找 是否左表多条记录可以对应右表一条记录...,即多对多,需要定义一个这两张表关系表来专门存放二者 关系 #一对一: 如果1和2都不成立,而是左表一条记录唯一对应右表一条记录,反之亦然。...这种情况很简单,就是在左表foreign key右 表基础上,将左表字段设置成unique即可 表三种关系 (1)书和出版社   一对多(或多对一):一个出版社可以出版多本书。...(20)); Query OK, 0 rows affected (0.09 sec) 这张表就存放了author表和book表关系,即查询二者关系查这表就可以了 mysql> create table...references user(id) on delete cascade on update cascade); Query OK, 0 rows affected (0.06 sec) 插入用户表记录

    78330

    Django关系映射

    什么是关系映射? 在关系型数据库,通常不会把所有数据都放在同一张表,不易于扩展。...UserMit # 进入Django Shell操作 create1 = UserMit.objects.create(name="henan) 有约束模型类UserId create2 = UserId.objects.create...="0dbccd1992474d30a4497b05295e807b") # 关联UserMit表user_id对应主键 一对一(查询数据) ---- 正向查询 正向查询:直接通过属性查询,则为查询...') 反向查询 没有属性一方,可以调用反向属性查询到关联另一方 反向关联属性为实例对象.引用类名(小写) 当反向引用不存在时候,则会触发异常 当UserId类定义了约束...MySQL创建多对多需要以来第三张表来完成 Django无需手动创建,Django自动完成 语法:在关联两个任意一个类models.ManyToManyField(MyModel

    1.7K20

    Django(ForeignKey)操作以及related_name作用

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

    2K10

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

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

    2K10

    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 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.2K20

    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

    Hibernate基于映射一对一关联关系

    基于映射一对一关联关系是Hibernate中常见关系映射之一。...在这种映射中,两个实体类之间存在一个一对一关系,其中一个实体类作为主实体类,另一个实体类作为从实体类,并且从实体类包含一个指向主实体类。...通过@JoinColumn注解name属性,我们指定了名称,确保与主实体类列名称保持一致。接下来,我们将给出一个示例来说明如何使用基于映射一对一关联关系。...该实体类@OneToOne注解用于建立一对一关系,并通过@MapsId注解映射了列和主键列关系。...通过@JoinColumn注解name属性,我们指定了名称,确保与主实体类列名称保持一致。通过以上基于映射一对一关联关系,我们可以轻松地进行关系操作。

    80030

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

    假设图书管理系统书、出版社、作者、作者详细信息四张表之间关系如下: """ 表关系 1)Book 和 Publish 一对多:在多一方 Book 2)Book 和 Author 多对多:在查询频率高一方...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外设置反向查询字段名:正向找字段名,反向找related_name...例子:部门没有了,部门员工里部门字段改为未分组部门id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系多个 3)db_constraint...,将两张表设置为级联,并将反向查询字段名设置为detail 数据库脏数据介绍 数据库中常见并发操作所带来了一致性问题包括:丢失修改,不可重复读,读“脏”数据,幻读。...子序列化 Django子序列化功能是:通过跨表查询数据然后对跨表查到数据反序列化。

    4.3K30

    Django-rest-framework过滤定制实例

    1、定义一个自定义filter.py模块,增加一个新过滤类 import django_filters #这个Q可以支持表查询,单下划线获取表字段,双下划线获取关联表, from django.db.models...import Q #引入自己模型 from app.item.models import ItemCategory #自定义过滤类,需要继承django_filter.rest_framework...#其中method指向自己定义过滤函数,label用于标识在测试API界面过滤界面字段,Filter_category控制查询字段 def category_filter(self, queryset...restful framework filter 自定义过滤 class AlertFilter(django_filters.rest_framework.FilterSet):...过滤定制实例就是小编分享给大家全部内容了,希望能给大家一个参考。

    1.7K10
    领券