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

如何在django中过滤两个外键

在Django中,可以使用__(双下划线)语法来过滤两个外键。具体步骤如下:

  1. 首先,在模型中定义两个外键字段。
代码语言:txt
复制
from django.db import models

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

class ModelB(models.Model):
    model_a = models.ForeignKey(ModelA, on_delete=models.CASCADE)
    status = models.CharField(max_length=100)

class ModelC(models.Model):
    model_b = models.ForeignKey(ModelB, on_delete=models.CASCADE)
    date = models.DateField()
  1. 接下来,通过使用__语法,可以在查询中过滤两个外键。
代码语言:txt
复制
from datetime import date

# 获取ModelC中ModelA的name为"example"并且ModelB的status为"active"的结果
result = ModelC.objects.filter(model_b__model_a__name="example", model_b__status="active")

# 获取ModelC中ModelA的name为"example"并且ModelB的status为"active"且date大于今天的结果
result = ModelC.objects.filter(model_b__model_a__name="example", model_b__status="active", date__gt=date.today())

这里,model_b__model_a__name表示通过ModelC的外键model_b访问到ModelB,再通过ModelB的外键model_a访问到ModelA的字段name。

对于过滤两个外键的应用场景,一个例子是在电商平台中,可以使用该方法来筛选同时满足商品分类和商品标签的商品。

推荐的腾讯云相关产品:TencentDB for MySQL、云数据库 Redis 版、云服务器 CVM。你可以在腾讯云官网中查找详细的产品介绍和文档。

注意:本回答基于Django框架和腾讯云,如需适应其他框架和云平台,请参考相应文档。

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

相关·内容

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.7K10
  • 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.9K30

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

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

    1.2K20

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

    场景 我们用Django的Model时,有时候需要关联。关联时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束的行为,在删除此条数据时,同事删除外关联的对象。...models.SET_NULL 设置关联的内容为null。只有设置了null=True时可用。当数据被删除时,被关联的内容被设置为null。...models.SET_DEFAULT 将的值设置为默认值。必须设置有默认值 。 models.SET()将SET()设置的值作为的值 ,如果传递了callable,则调用它的结果。...如果后端数据库有强制关联操作,这是容易报错:IntegrityError,除非你在数据库手动添加了SQL的ON DELETE约束。

    2K10

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

    两张表建立了一对一字段,在A表,那么先往B表写数据就更合理。...假设图书管理系统书、出版社、作者、作者详细信息四张表之间的关系如下: """ 表关系 1)Book 和 Publish 一对多:在多的一方 Book 2)Book 和 Author 多对多:在查询频率高的一方...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外设置反向查询的字段名:正向找字段名,反向找related_name...子序列化 Django的子序列化的功能是:通过跨表查询数据然后对跨表查到的数据反序列化。...如果涉及到通过进行跨表查询,然后再将查询数据反序列化到前台就需要用到子序列化,比如下面的例子:我们查询出版社信息的时候连带将book表的该出版社所出版过的书名一并查出来。

    4.3K30

    Django 模型查询2.3

    简介 查询集表示从数据库获取的对象集合 查询集可以含有零个、一个或多个过滤过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句 接下来主要讨论如下知识点...):一个对象构成一个字典,然后构成一个列表返回 写法: filter(1=值1,2=值2) 等价于 filter(1=值1).filter(2=值2) 返回单个值的方法 get():返回单个满足条件的对象...会将查询的结果存在查询集的缓存,并返回请求的结果,接下来对查询集求值将重用缓存的结果 情况一:这构成了两个查询集,无法重用缓存,每次查询都会与数据库进行一次交互,增加了数据库的负载 print([e.title...()、get()的参数 语法:属性名称__比较运算符=值 表示两个下划线,左侧是属性名称,右侧是比较类型 对于,使用“属性名_id”表示的原始值 转义:like语句中使用了%与,匹配数据的%与...,会合并为And进行 需要进行or查询,使用Q()对象 Q对象(django.db.models.Q)用于封装一组关键字参数,这些关键字参数与“比较运算符”的相同 from django.db.models

    2.4K20

    Django-Multitenant,分布式多租户数据库项目实战(PythonDjango+Postgres+Citus)

    目录 项目源码 安装 支持的 Django 版本/前提条件。 用法 模型变化 使用 mixins 更改模型 在 db 层自动化复合: 在哪里设置租户?...支持的 API Python/Django 支持分布式多租户数据库, Postgres+Citus。...: 在 db 层自动化复合: 使用 TenantForeignKey 在租户相关模型之间创建将自动将 tenant_id 添加到引用查询(例如 product.purchases)和连接查询(例如...如果要确保在 db 层创建复合(带有 tenant_id),则应将 settings.py 的数据库 ENGINE 更改为 django_multitenant.backends.postgresql...只需在身份验证时设置它,库将确保其余部分(将 tenant_id 过滤器添加到查询)。上面的示例实现如下: 在您的设置,您需要更新 MIDDLEWARE 设置以包含您创建的设置。

    1.9K10

    django后台管理-admin

    0922自我总结 django后台管理-admin 一.模型注册 admin.py 注册方式一: #在对于注册的app的admin文件中导入模型然后注册模型 admin.site.register(导入的模型类...list_editable 设置默认可编辑字段 list_editable = ['machine_room_id', 'temperature'] #fk_fields 设置显示字段...list_filter =('trouble', 'go_time', 'act_man__user_name', 'machine_room_id__machine_room_name') #过滤器...一般ManyToManyField多对多字段用过滤器;标题等文本字段用搜索框;日期时间用分层筛选。 过滤器如果是需要遵循这样的语法:本表字段__表要显示的字段。...:“user__user_name” 3、颜色显示 from django.db import models from django.contrib import admin from django.utils.html

    87810

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

    最近博客在做新功能,就是增加了两个模型,分别是专题和主题,主要就是用来对文章进行系列划分,在这个设计过程,文章和主题会进行一个关联,当主题的数量很多的时候,文章在选择要关联的主题的时候会非常难选。...我希望在文章选择主题的时候可以输入关键字来搜过滤,这样可以减少可选项。基于这个需求,我又重新去看了一下Django关于admin的教程,终于找到了方法,现在分享一下。...['name', 'subject__name'] @admin.register(Article) class ArticleAdmin(admin.ModelAdmin): # 可以给的选择增加搜索...,前提是的管理模型必须设置search_fields作为搜索条件 autocomplete_fields = ['topic'] 看一下效果: 这里已经出现了搜索框,可以通过搜索条件来过滤选项...总结 本篇介绍了Django的admin.ModelAdmin中使用autocomplete_fields字段来给关联模型添加过滤搜索。

    60020

    Django框架学习(三)

    b)Django的模板变量不能直接进行算术运算 2、模板控制语句:条件判断和for循环 a)条件判断:Django模板在进行条件判断时候,比较操作符两边必须有空格 b)for循环:Django模板的...| 过滤器(参数...)}} b) Django模板过滤器的使用: {{ 模板变量 | 过滤器:参数 }} 注意:Django过滤器:号之后只能接收一个参数 ?...,默认值是False 在设置时,需要通过on_delete选项指明主表删除数据时,对于引用表数据如何处理,在django.db.models包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外数据...PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被应用的数据 SET_NULL 设置为NULL,仅在该字段null=True允许为null时可用 4.3迁移生成数据表...工具提供了shell命令,帮助我们配置好当前工程的运行环境(连接好数据库等),以便可以直接在终端执行测试python语句。

    1.8K40

    django 模型的计算字段实例

    ') given_name = models.CharField(max_length=20, verbose_name='名') def name(self): # 计算字段要显示在修改页面只能定义在只读字段...self.given_name) admin.py class PersonAdmin(admin.ModelAdmin): def name(self,obj): # 这个方法会得到两个参数...用于显示时的名字 , 没有这个,字段标题将显示'name' readonly_fields = ('name',) admin.site.register(Person, PersonAdmin) 补充知识:django...如何在 search_fields 包含字段 在search_fields中加入一个的名字是不能查询的,要写成(键名__的字段名)的形式. search_fields = ('attributename...','goodsclass__cn') # goodsclass__cn 就可以搜索的名字中有搜索词的条目了, # 比如搜索手机的分辨率,而不是电脑的分辨率,就可以搜索'手机 分辨率' 以上这篇django

    4.4K20

    Django的数据迁移与数据库版本控制:概念、实践与优化策略

    Django提供了一个强大的数据迁移工具,可以帮助开发者管理数据库模式的变更,并且保持数据库与代码的同步。本文将介绍如何在Django中使用数据迁移和数据库版本控制,以及一些常见的最佳实践。...示例代码下面是一个简单的示例,演示了如何在Django定义一个简单的模型,并通过数据迁移将其应用到数据库:# models.pyfrom django.db import models​class...数据迁移与约束当存在外约束时,数据迁移可能会变得复杂。在修改涉及的模型时,需要谨慎处理迁移顺序,以确保外约束的一致性。...我们还展示了示例代码,演示了如何在Django定义模型并执行数据迁移的过程。...在接下来的部分,我们进一步讨论了数据迁移与数据库版本控制的进阶应用,包括自动化迁移、数据迁移的回滚、数据库备份与恢复、多数据库支持以及约束等。

    21910

    Django教程 —— 模型类条件查询

    引言 在之前的 Django模型设计 简单的介绍了如何利用模型类对数据库进行增删改查,在这篇主要介绍使用模型类对数据库进行条件查询。让大家更加熟悉 Django 操作数据库。...通过 属性名_id 表示对应对象的 id 值。 语法如下: 属性名称__比较运算符=值 说明:属性名称和比较运算符间使用两个下划线,所以属性名不能包括多个下划线。...答:使用 F对象,被定义在 django.db.models 。 语法如下: F(属性名) 例:查询阅读量大于等于评论量的图书。...聚合函数包括:Avg、Count、Max、Min、Sum,被定义在django.db.models 。 例:查询图书的总阅读量。...,格式如下: {'聚合类小写__属性名':值} : {'sum__read': 29000} 使用 count 时一般不使用 aggregate() 过滤器。

    1.1K20

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

    在这个表单,Question字段是一个select选择框,包含了当前数据库中所有的Question实例。Django在admin站点中,自动地将所有的关系展示为一个select框。...在我们的例子,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。每一个包含关系的对象都会有这个绿色加号。...填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice的关联对象。通俗讲就是,新建一个Question并作为当前Choice的。...在QuestionAdmin添加下面的代码: list_filter = ['pub_date'] 它添加了一个“过滤器”侧边栏,这样就可以通过pubdate字段来过滤显示question: ?...__path__)" 然后替换文件的{{ site_header|default:_('Django administration') }}(包括两个大括号),换成你想要命名的名字即可。

    3.6K60
    领券