Django ORM过滤器默认值,返回所有对象



我有一个模型Book,它有一个字段year_of_publishing。用户输入年份,我想过滤Book的集合,得到当年出版的所有书籍。

year = self.cleaned_data.get('year', SOME_DEFAULT_VALUE)
books = Book.objects.filter(year_of_publishing=year)

然而,用户可能会将year字段留空,我想设置一些默认值,在.filter函数中Django ORM将返回所有书籍,就像这个过滤器根本不存在一样。我应该使用什么值?我想它应该是独立于类型的,所以我可以将它用于Char、Choice和其他类型的字段。

您可以将一个空字典传递给.filter()以返回所有结果,或者过滤所需的字段/值:

filters = {}
year = request.GET.get('year')
if year:
    filters['year'] = year
books = Book.objects.filter(**filters)

您可以使用字典构建查询集:

parameters = ['year', 'foo', 'bar']
query_dict = {}
for parameter in parameters:
    if self.cleaned_data.get(parameter, None):
        query_dict[parameter] = self.cleaned_data.get(parameter)
books = Book.objects.filter(**query_dict)

最新更新