首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对查询集使用annotate和distinct

对查询集使用annotate和distinct
EN

Stack Overflow用户
提问于 2021-04-19 15:24:54
回答 1查看 42关注 0票数 0

在这里,我试图在过滤掉不同的相关值之后,从PunchRawData中获取每个位置的计数。为此,我需要以下代码来协同工作。

代码语言:javascript
复制
queryset = PunchRawData.objects.filter(punch_type=IN, actual_clock_datetime__date=actual_clock_datetime).distinct('employee')
trade_based = queryset.values('employee__position').annotate(emp_count=Count('employee__position'))

但是我得到了这个错误:

代码语言:javascript
复制
NotImplementedError: annotate() + distinct(fields) is not implemented.

如何解决这个问题?

EN

回答 1

Stack Overflow用户

发布于 2021-04-19 16:03:47

首先应用注解,然后使用distinct。另外,您只需使用一个查询即可实现这一点,不需要另一个变量

代码语言:javascript
复制
queryset = PunchRawData.objects.filter(punch_type=IN, actual_clock_datetime__date=actual_clock_datetime).annotate(emp_count=Count('employee__position', distinct=True)).values('emp_count')

希望这对你有用。

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

https://stackoverflow.com/questions/67157610

复制
相关文章

相似问题

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