А, това беше добро предизвикателство. Успях да тествам от PostGres и мога да потвърдя, че работи. MySQL кодът трябва да е доста близо. Има обаче бележка за документация CONVERT_TZ :
MySQL (използвайки CONVERT_TZ(dt , from_tz, to_tz) )
from_tz = 'UTC'
to_tz = 'Australia/ACT'
report = Sale.objects.extra(
{
'day': "date(CONVERT_TZ(sale_date, '{from_tz}', '{to_tz}'))".format(
from_tz=from_tz,
to_tz=to_tz
)
}
).values(
'day'
).annotate(
day_total=Sum('total')
)
PostGres: (използвайки В ЧАСОВА ЗОНА )
time_zone = 'Australia/ACT'
report = Sale.objects.extra(
{'day': "date(sale_date) AT TIME ZONE '{0}'".format(time_zone)}
).values(
'day'
).annotate(
day_total=Sum('total')
)