通常,无法
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'))
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)