Why Django Group by id Field? Here is queryset:
MyModel.objects\
.filter(
status=1,
created__gte=datestart,
created__lte=dateend)\
.values('terminal_id')\
.annotate(
total_pa=Sum('amount'),
total_ar=Sum('amount_result')).query
But it order and group by pk field.
... GROUP BY payment
.id
ORDER BY payment
.id
...
Instead of
... GROUP BY payment
.terminal_id
ORDER BY payment
.terminal_id
...
See the "Warning" here:
https://docs.djangoproject.com/en/1.8/topics/db/aggregation/#interaction-with-default-ordering-or-order-by
Perhaps the default ordering is getting in the way. Try adding
.order_by()
to the end of your query to see if that clears the ordering.