首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何正确过滤反向ManyToMany?

如何正确过滤反向ManyToMany?
EN

Stack Overflow用户
提问于 2016-04-19 09:35:09
回答 2查看 31关注 0票数 0

我不知道如何在ManyToMany中过滤反向Django。我想得到LanguageLevel对象,它至少与一个UserProfile连接。

在人类中:所有的语言,比如至少一个用户都能说这种语言。

我有个模特:

代码语言:javascript
复制
class LanguageLevel(models.Model):
    ...

代码语言:javascript
复制
class UserProfile(models.Model):
    ...
   language_levels = models.ManyToManyField('LanguageLevel', blank=True, related_name='translators')
    ...

已试过:

代码语言:javascript
复制
active_language_levels = LanguageLevel.objects.filter(lambda x: len(x.translators)!=0)

代码语言:javascript
复制
for language_level in LanguageLevel.objects.all():
        print language_level.translators
        if len(language_level.translators)>0:
            print 'ok'
            print language_level
        else:
            print 'no'
            print language_level
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-04-19 09:50:48

我想你是在找这样的东西:

代码语言:javascript
复制
from django.db.models import Count

LanguageLevel.objects.all() \
                .annotate(translators_count=Count('translators__id')) \
                .filter(translators_count__gte=1)

只需在translators__id上添加适当的链接就可以计算每个用户的不同条目。

如果要为特定用户选择语言,只需在注释前传递适当的查询集:

代码语言:javascript
复制
LanguageLevel.objects.filter(translators__id=user_id)
                .annotate(...)
票数 1
EN

Stack Overflow用户

发布于 2016-04-19 09:47:47

您不能使用django orm通过M2M字段进行筛选。相反,你可以遵循这个解决办法,

LanguageLevel.objects.all().values('language_levels__id')

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36714391

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档