2

我有几个模型设置如下:

class Bar(models.Model):
  baz = models.CharField()

class Foo(models.Model):
  bar1 = models.ForeignKey(Bar)
  bar2 = models.ForeignKey(Bar)
  bar3 = models.ForeignKey(Bar)

在代码的其他地方,我最终得到了一个 Bar 的实例,并且需要找到它以某种能力附加到的 Foo。现在我想出了使用 Q 进行多重 OR 查询,如下所示:

foo_inst = Foo.objects.get(Q(bar1=bar_inst) | Q(bar2=bar_inst) | Q(bar3=bar_inst))

我需要弄清楚的是,这 3 个案例中的哪一个实际命中,至少是成员的名称(bar1、bar2 或 bar3)。有没有好的方法来做到这一点?有没有更好的方法来构建查询以收集该信息?

4

2 回答 2

1
try:
    Foo.objects.get(bar1=bar_inst)
    print 'bar1'
except Foo.DoesNotExist:
    try:
        Foo.objects.get(bar2=bar_inst)
        print 'bar2'
    except Foo.DoesNotExist:
        try:
           Foo.objects.get(bar3=bar_inst)
           print 'bar3'
        except Foo.DoesNotExist:
           print 'nothing found'

还可以考虑将related_name添加到模型的所有条形字段中。

于 2012-09-17T08:08:54.430 回答
0

您可以进行更改并使用ChoiceField?

BAR_VERSIONS = (
    ('Bar 1', 'bar1'),
    ('Bar 2', 'bar2'),
    ('Bar 3', 'bar3'),
)


class Bar(models.Model):
  baz = models.CharField()

class Foo(models.Model):
  bar = models.ForeignKey(Bar)
  bar_version = models.ChoiceField(choices=BAR_VERSIONS)

然后:

try:
    foo_instance = Foo.objects.get(bar=bar_instance)
except Foo.DoesNotExist:
    # Handle Exception
    pass
else:
    print(foo_instance.bar_version)

更新: 根据您的评论,由于想法是设置 none 或 all bars ,您仍然可以使用这种方法,但使用ManyToManyField带有through参数的 a 。bar4如果您想添加-barn而不是扩展您的 try-except 瀑布,这将使它在未来变得更好和可扩展。

https://docs.djangoproject.com/en/dev/topics/db/models/#intermediary-manytomany

class Bar(models.Model):
  baz = models.CharField()

class Foo(models.Model):
  bars = models.ManyToManyField(bar, through='FooBars')

class FooBars(models.Model):
  foor = models.ForeignKey(Foo)
  bar = models.ForeignKey(Bar)
  bar_version = models.ChoiceField(choices=BAR_VERSIONS)
于 2012-09-17T08:10:39.233 回答