按天过滤 django 查询

Filter django query by day

我正在按月份过滤查询。 问题是在我的本地机器上一切正常,我得到了预期的结果,但在生产服务器中查询集 returns None.

本地

>>> Works.objects.filter(work_estimated_start_time__day=06)
>>> [<Works: 61: ns>]
>>> w[0].work_estimated_start_time
>>> datetime.datetime(2015, 12, 6, 15, 38, 37, tzinfo=<UTC>)

服务器

>>> Works.objects.filter(work_estimated_start_time__day=06)
>>> []
>>> w = Works.objects.all()
>>> w[0].work_estimated_start_time
>>> datetime.datetime(2015, 12, 6, 15, 38, 2, tzinfo=<UTC>)

数据库数据都差不多

来自两个环境的查询(两者相同):

SELECT api_works.`work_id`, `api_works`.`work_central_id_id`, `api_works`.`work_user_id_id`, `api_works`.`work_driver_id_id`, `api_works`.`work_truck_id_id`, `api_works`.`work_estimated_start_time`, `api_works`.`work_start_time`, `api_works`.`work_end_time`, `api_works`.`work_first_pause_start_time`, `api_works`.`work_first_pause_end_time`, `api_works`.`work_second_pause_start_time`, `api_works`.`work_second_pause_end_time`, `api_works`.`work_creation_date`, `api_works`.`work_status`, `api_works`.`work_done`, `api_works`.`work_cancelation`, `api_works`.`work_enterprise_id_id`, `api_works`.`work_truck_type`
FROM `api_works`
WHERE EXTRACT(DAY FROM CONVERT_TZ(`api_works`.`work_estimated_start_time`, 'UTC', Europe/Zurich)) = 6

谁能帮帮我? 谢谢

MySQL Django 中没有本机时区操作。

USE_TZTrue 时,日期时间字段在过滤前转换为当前时区。为此,您必须安装 pytz and load the time zone tables with mysql_tzinfo_to_sql.

您的生产数据库没有 mysql_tzinfo_to_sql 加载。

解决方案 1

在生产环境中加载 mysql_tzinfo_to_sql

解决方案 2

USE_TZ 设置为 False

解决方案 3

将数据库更改为 PostgreSQL。 TZ 支持是开箱即用的。

看看 example MySQL 没有 TZ 支持。