Django用条件表达式注释,如何应用distinct()

Gor*_*ran 5 django django-queryset django-views django-annotate

我有一个有点复杂的查询,我使用带有条件表达式的注释,代码如下:

from django.db.models import Q, F, When, CharField, Value, Case
from django.contrib.auth.models import User


ATT_PREFIX = 'f'

def get_it(mymodel, fields):

    q = Q(modelone__modeltwo__mymodel=mymodel)

    query_set = {
        'aid': F('modelone__id'),
        'name': F('modelfour__name'),
    }

    for f in fields:
        query_set[ATT_PREFIX + str(f.id)] = Case(
            When(Q(modelfive__modelsix=f) &
                 Q(modelfive__user__email=F('email')),
                 then='modelfive__entry'),
            default=Value(''),
            output_field=CharField(),
        )

    return User.objects.filter(q).annotate(**query_set)
Run Code Online (Sandbox Code Playgroud)

收集的属性辅助和名称F()具有预期值。使用条件表达式的第二部分有一个问题:如果 feilds 列表包含 2 个对象,那么Case()当条件满足时我有 2 个用户对象。因此,(aid, name, f17, f18) 我得到了两个对象,而不是一个具有属性的对象:

obj1 attributes (aid, name, f17)
obj2 attributes (aid, name, f18)
Run Code Online (Sandbox Code Playgroud)

Django 1.10,Python3.5

小智 0

尝试这个

q = Q(modelone__modeltwo__mymodel=mymodel).distinct()
Run Code Online (Sandbox Code Playgroud)