代码之家  ›  专栏  ›  技术社区  ›  Ram Rachum

Django:跨三个模型进行注释

  •  4
  • Ram Rachum  · 技术社区  · 6 年前

    我想做一个复杂的 annotate QuerySet 我不知道如何建造它。你能帮忙吗?

    我会尽量简化我的设置:

    我有三种型号: Movie Actor Casting .

    每个 铸造 具有 电影 和一个 ,和 CharField 对于 role

    铸造

    我想得到一个电影列表,每部电影都会有一个注释,说明约翰尼·德普在那部电影中扮演的角色。如果他没演那部电影,那应该是 None

    请注意,我给一个特定的演员,我不想超过所有演员。

    1 回复  |  直到 6 年前
        1
  •  1
  •   willeM_ Van Onsem    6 年前

    你可以 .annotate(..) 这是一个 Case(..)

    Movie.objects.annotate(
        role=Min(Case(
            When(casting__actor=my_actor, then=F('casting__role')),
            default=None
        ))
    )
    

    Movie 对象将具有一个属性 .role 这是最重要的 role 为了那个演员。

    如果有的话 倍数 None .