i have django model this:
class event(models.model): user = models.charfield(max_length=255) pay_time = models.datetimefield(default=timezone.now)
i need calculate average number of records per month have group of users. have user names in list , want group month , year use in average calculation. query this:
from django.db import models django.db.models import func, f, count class month(func): function = 'extract' template = '%(function)s(month %(expressions)s)' output_field = models.integerfield() class year(func): function = 'extract' template = '%(function)s(year %(expressions)s)' output_field = models.integerfield() #ru list of usernames want average per month trx = event.objects.filter(user__in=ru).annotate(m=month('pay_time'), y=year('pay_time')).values('m', 'y').annotate(c=count('id'))
when run query results thought wanted. that's sample of got:
<queryset [{'y': 2016, 'c': 61098, 'm': 4}, {'y': 2016, 'c': 104632, 'm': 5}]>
i wanted make sure ran query:
trx2 = event.objects.filter(user__in=ru, pay_time__year=2016, pay_time__month=4)
and got result 60990 records.
means results got first query incorrect. know can use second query in loop want slow compared running 1 query using group by.
thanks,
edit:
here output of print trx.query
:
select extract(year `events_event`.`pay_time`) `y`, extract(month `events_event`.`pay_time`) `m`, count(`events_event`.`id`) `c` `events_event` `events_event`.`user` in ('user1', 'user2') group extract(year `events_event`.`pay_time`), extract(month `events_event`.`pay_time`) order null
and output of print trx2.query
:
select `events_event`.`id`, `events_event`.`user`, `events_event`.`pay_time`, `events_event` (`events_event`.`user` in ('user1', 'user2') , `events_event`.`pay_time` between 2015-12-31 22:00:00 , 2016-12-31 21:59:59.999999 , extract(month convert_tz(`events_event`.`pay_time`, 'utc', africa/cairo)) = 4)
i think solution here, in convert_tz
extract(month convert_tz(`events_event`.`pay_time`, 'utc', africa/cairo))
you can try
class month(func): function = 'extract' template = "%(function)s(month convert_tz(%(expressions)s, 'utc', 'africa/cairo'))" output_field = models.integerfield()
Comments
Post a Comment