[Answered ]-Why is Model.objects.filter returning an empty query?

1πŸ‘

βœ…

It seems django handles __year and the other __ date extractions differently with annotate or F expressions, compared to when you use it in a filter.

For example in Postgres, the query generated with filter(pub_date__year=F('mod_date__year')) is:

WHERE EXTRACT(\'year\' FROM pub_date") = ("mod_date")

which would result with an error. But if used with an integer year like filter(pub_date__year=2021):

WHERE "pub_date" BETWEEN 2021-01-01 AND 2021-12-31'

USING EXTRACT:

To solve this, try to use Extract to generate the correct filter:

from django.db.models.functions import Extract


Entry.objects.filter(pub_date__year=Extract('mod_date', 'year'))

Which will generate this query:

WHERE EXTRACT(\'year\' FROM "pub_date") = (EXTRACT(\'year\' FROM "mod_date"))'
πŸ‘€Brian Destura

Leave a comment