7

我想使用date_trunc SQL 函数,但它似乎不适用于时区。

用 Django 测试 1:

from django.db import connection
cursor = connection.cursor()
cursor.execute("""
SELECT (date_trunc('day', when_start)) AS "d", 
COUNT("stats_histo_call"."id") AS "agg"
FROM "stats_histo_call"
WHERE ("stats_histo_call"."offre_id" = 28 
AND "stats_histo_call"."when_start" BETWEEN '2014-08-04 00:00:00+02:00' and '2014-08-08 23:59:59.999999+02:00')
GROUP BY (date_trunc('day', when_start))""")

print cursor.fetchone()
print cursor.fetchone()
print cursor.fetchone()
print cursor.fetchone()
print cursor.fetchone()

postgres 日志中的 SQL 查询:

2014-08-21 15:18:31 CEST LOG:  instruction : SELECT (date_trunc('day', when_start)) AS "d", COUNT("stats_histo_call"."id") AS "agg" FROM "stats_histo_call" WHERE ("stats_histo_call"."offre_id" = 28  AND "stats_histo_call"."when_start" BETWEEN '2014-08-04 00:00:00+02:00' and '2014-08-08 23:59:59.999999+02:00') GROUP BY (date_trunc('day', when_start))

结果 :

(datetime.datetime(2014, 8, 4, 0, 0, tzinfo=<UTC>), 12053L)
(datetime.datetime(2014, 8, 5, 0, 0, tzinfo=<UTC>), 9533L)
(datetime.datetime(2014, 8, 6, 0, 0, tzinfo=<UTC>), 7424L)
(datetime.datetime(2014, 8, 7, 0, 0, tzinfo=<UTC>), 6588L)
(datetime.datetime(2014, 8, 8, 0, 0, tzinfo=<UTC>), 5826L)

使用 psql 测试 2:

psql -U user -d dbname -c "<the same SQL Query>"

postgres 日志中的 SQL 查询:

2014-08-21 15:23:00 CEST LOG:  instruction : SELECT (date_trunc('day', when_start)) AS "d", COUNT("stats_histo_call"."id") AS "agg" FROM "stats_histo_call" WHERE ("stats_histo_call"."offre_id" = 28  AND "stats_histo_call"."when_start" BETWEEN '2014-08-04 00:00:00+02:00' and '2014-08-08 23:59:59.999999+02:00') GROUP BY (date_trunc('day', when_start))

结果 :

           d            |  agg
------------------------+-------
 2014-08-04 00:00:00+02 | 12050
 2014-08-05 00:00:00+02 |  9535
 2014-08-06 00:00:00+02 |  7417
 2014-08-07 00:00:00+02 |  6594
 2014-08-08 00:00:00+02 |  5828
(5 lignes)

SQL 查询似乎是一样的,那么为什么 Django 在 UTC 中返回date_trunc而不是 psql 呢?

4

0 回答 0