首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django - filter ManyToManyField?

Django - filter ManyToManyField?
EN

Stack Overflow用户
提问于 2011-02-03 01:59:48
回答 2查看 2K关注 0票数 1

我不确定最好的方式来描述它是什么,我试图这样做,所以请原谅我的标题。

我有两个模型,用户和组。Group包含字段members,是指用户的ManyToManyField。

给定一个用户,我希望找到该用户所属的所有组。

我的想法是这样做:

代码语言:javascript
复制
groups = Group.objects.filter(user in members)

差不多吧。即使我意识到这是不对的

我试着通读这个链接,但不知道如何应用:http://docs.djangoproject.com/en/dev/topics/db/queries/#spanning-multi-valued-relationships

谢谢

编辑:

解决了groups = Group.objects.filter(members__username=user.username)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-02-03 02:19:38

如果你有用户,并且你想要他的组,那么就开始从它开始查询,而不是反过来;)

下面是一个例子:

代码语言:javascript
复制
james = User.objects.get(pk= 123)
james_groups = james.group_set.all()
票数 2
EN

Stack Overflow用户

发布于 2011-02-03 03:09:36

最简洁的方法可能是

代码语言:javascript
复制
groups = user1.group_set.all()

这为您提供了一个可迭代的查询集。

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

https://stackoverflow.com/questions/4878030

复制
相关文章

相似问题

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