按月和日过滤Django日期时间字段
有人可以向我解释为什么以下过滤器在月份和日期级别不起作用吗?按年份进行过滤似乎有效,但其他两个方法却无效。
>>> clicks.count()36
>>> date = clicks[0].created
>>> date.month
2
>>> date.year
2014
>>> date.day
1
>>> clicks.filter(created__month=2)
[]
>>> clicks.filter(created__month=02)
[]
>>> clicks.filter(created__month='02')
[]
>>> clicks.filter(created__month='2')
[]
>>> clicks.filter(created__month=date.month)
[]
>>> clicks.filter(created__day=date.day)
[]
快速更新以演示在创建和处理查询集之前我得到了相同的行为:
>>> clicks = PreviewClick.objects.filter(created__month = 2)>>> clicks.count()
0
>>> clicks = PreviewClick.objects.filter(created__month = 02)
>>> clicks.count()
0
>>> clicks = PreviewClick.objects.filter(created__month = '02')
>>> clicks.count()
0
>>> clicks = PreviewClick.objects.filter(created__month = '2')
>>> clicks.count()
0
这里有更多值得深思的地方:
>>> clicks = PreviewClick.objects.all()>>> counter = 0
>>> for click in clicks:
... if click.created.month == 2:
... counter += 1
...
>>> counter
35
回答:
Django文档给出了将时区定义安装到数据库的指令:
SQLite:安装pytz
-转换实际上是在Python中执行的。
PostgreSQL:无要求(请参阅时区)。
Oracle:无要求(请参阅选择时区文件)。
MySQL:使用安装pytz和加载时区表mysql_tzinfo_to_sql
。
在我的情况下:mysql和Mac Os,以下命令解决了这个问题:
sudo mysql_tzinfo_to_sql /usr/share/zoneinfo/ | mysql -u root mysql
以上是 按月和日过滤Django日期时间字段 的全部内容, 来源链接: utcz.com/qa/412351.html