在这里,我试图在过滤掉不同的相关值之后,从PunchRawData中获取每个位置的计数。为此,我需要以下代码来协同工作。
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'))但是我得到了这个错误:
NotImplementedError: annotate() + distinct(fields) is not implemented.如何解决这个问题?
发布于 2021-04-19 16:03:47
首先应用注解,然后使用distinct。另外,您只需使用一个查询即可实现这一点,不需要另一个变量
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')希望这对你有用。
https://stackoverflow.com/questions/67157610
复制相似问题