我想找到至少在一个组中的所有用户。
我找到了一个解决办法
from django import setup
setup()
from django.contrib.auth.models import User
user_without_group = User.objects.update_or_create(username='user-without-group')[0]
user_without_group.groups.clear()
query = User.objects.filter(groups__isnull=False).values_list('username', flat=True)
print (query.query)
print list(query)
assert user_without_group.username not in query..。但解决办法不太好。有比groups__isnull=False更明显的解决方案吗?
更新
为什么我认为这个解决方案不太好:我认为这并不明显。它不容易阅读和理解。如果您向知道Python但从未使用django ORM的人展示这一点,我认为他不会立即理解这意味着什么。
User.objects.filter(groups__isnull=False)发布于 2019-02-01 18:19:19
您可以考虑添加一个可读的自定义查找字段,如group__at_least_one=True by 自定义查找
发布于 2019-01-25 15:29:49
我不知道你对groups__isnull=False有什么意见,这是绝对好的。但是请注意,它完全等同于groups=None,您可能会发现它更好一些。
发布于 2019-01-25 14:35:03
你也可以:
Group.objects.values_list('user').distinct('user')并且您将获得唯一的用户只有1和更多的Group。
https://stackoverflow.com/questions/54367178
复制相似问题