我必须通过动态值(可以是无)过滤查询集:我可以简单地写:
filtered_queryset = queryset.filter(field=value)
还是我应该检查无:
if value is None:
filtered_queryset = queryset.filter(field__isnull=True)
else:
filtered_queryset = queryset.filter(field=value)
行为是否取决于特定的 DBMS?
我必须通过动态值(可以是无)过滤查询集:我可以简单地写:
filtered_queryset = queryset.filter(field=value)
还是我应该检查无:
if value is None:
filtered_queryset = queryset.filter(field__isnull=True)
else:
filtered_queryset = queryset.filter(field=value)
行为是否取决于特定的 DBMS?
ORM 将为None您处理(将其转换为 NULL)并返回一个QuerySet对象,因此除非您需要捕获None输入,否则第一个示例很好。
>>> User.objects.filter(username=None)
[]
>>> type(_)
<class 'django.db.models.query.QuerySet'>
>>> str(User.objects.filter(username=None).query)
SELECT "auth_user"."id", "auth_user"."username", "auth_user"."first_name", "auth_user"."last_name", "auth_user"."email", "auth_user"."password", "auth_user"."is_staff", "auth_user"."is_active", "auth_user"."is_superuser", "auth_user"."last_login", "auth_user"."date_joined" FROM "auth_user" WHERE "auth_user"."username" IS NULL
我更喜欢处理得更好的第二种解决方案
Update
if value is None:
filtered_queryset = queryset.filter(field__isnull=True)
# Do some proessing with filtered_queryset object with None values
else:
filtered_queryset = queryset.filter(field=value)
# Do some proessing with filtered_queryset object with not NULL values
查询集可以处理 Null 值。基于此, User.objects.filter(username=None) 这将仅获取 username=NULL的值