我试图过滤一个DateTimeField与日期比较。我的意思是:

MyObject.objects.filter(datetime_attr=datetime.date(2009,8,22))

我得到一个空的查询集列表作为答案,因为(我认为)我没有考虑时间,但我想要“任何时间”。

Django中有简单的方法来做这个吗?

我在datetime中设置了时间,不是00:00。


当前回答

Model.objects.filter(datetime__year=2011, datetime__month=2, datetime__day=30)

其他回答

MyObject.objects.filter(datetime_attr__date=datetime.date(2009,8,22))
Mymodel.objects.filter(date_time_field__contains=datetime.date(1986, 7, 28))

以上就是我所使用的。它不仅有效,而且有一些内在的逻辑支持。

这里有一个有趣的技术——我利用Django在MySQL上实现的startswith过程来实现仅通过日期查找datetime的结果。基本上,当Django在数据库中查找时,它必须为DATETIME MySQL存储对象做一个字符串转换,所以你可以过滤它,忽略日期的时间戳部分——这样%LIKE%只匹配日期对象,你会得到给定日期的每个时间戳。

datetime_filter = datetime(2009, 8, 22) 
MyObject.objects.filter(datetime_attr__startswith=datetime_filter.date())

这将执行以下查询:

SELECT (values) FROM myapp_my_object \ 
WHERE myapp_my_object.datetime_attr LIKE BINARY 2009-08-22%

在这种情况下,LIKE BINARY将匹配日期的所有内容,而不管时间戳是什么。包括如下值:

+---------------------+
| datetime_attr       |
+---------------------+
| 2009-08-22 11:05:08 |
+---------------------+

希望这能帮助到每个人,直到Django拿出解决方案!

YourModel.objects.filter(datetime_published__year='2008', 
                         datetime_published__month='03', 
                         datetime_published__day='27')

//在注释后编辑

YourModel.objects.filter(datetime_published=datetime(2008, 03, 27))

不工作,因为它创建了一个时间值设置为0的datetime对象,因此数据库中的时间不匹配。

你可以这样做

MyObject.objects.filter(datetime_field__date=datetime.date(2009,8,22))

或者如果你想在两个日期之间过滤

MyObject.objects.filter(
    datetime_field__date__range=(datetime.date(2009,8,22), datetime.date(2009,9,22))
)