栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在Django中遍历GenericForeignKey?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在Django中遍历GenericForeignKey?

通常,无法

GenericForeignKey
按照您尝试的方式在此方向上遍历a
。A
GenericForeignKey
可以指向您的应用程序中的任何模型,不仅指向
Bar
它的子类。因此,
Foo.objects.filter(bar__somefield='somevalue')
无法知道您当前打算使用的目标模型,因此无法确定目标模型具有哪些字段。实际上,执行这种查询时无法选择要与哪个数据库表连接-
它可以是任何表,具体取决于的值
Foo.content_type

如果确实要在联接中使用通用关系,则必须

GenericRelation
在该关系的另一端定义一个。这样,您可以让Django知道它应该在另一侧寻找哪种模型。

例如,您可以按以下方式创建

BarX
BarY
模型:

class BarX(Bar):    name = models.CharField(max_length=10, default='bar x')    foos = GenericRelation(Foo, related_query_name='bar_x')class BarY(Bar):    name = models.CharField(max_length=10, default='bar y')    foos = GenericRelation(Foo, related_query_name='bar_y')

如果执行此操作,则可以执行以下查询:

Foo.objects.filter(bar_x__name='bar x')Foo.objects.filter(bar_y__name='bar y')

但是,您必须选择一个目标模型。这是您无法以任何方式真正克服的局限性。每个数据库联接都需要事先知道它在哪个表上运行。

如果绝对需要同时允许

BarX
BarY
作为目标,则应该可以使用
Q
表达式在查询过滤器中明确列出这两个对象:

Foo.objects.filter(Q(bar_x__name='bar x') | Q(bar_y__name='bar y'))


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/637175.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号