Answers:
您可以这样做:
Name.objects.exclude(alias__isnull=True)
如果您需要排除空值和空字符串,则首选方法是将条件链接在一起,如下所示:
Name.objects.exclude(alias__isnull=True).exclude(alias__exact='')
将这些方法链接在一起基本上可以独立检查每个条件:在上面的示例中,我们排除了其中alias
为null 或空字符串的行,因此您将获得所有Name
具有非空,非空alias
字段的对象。生成的SQL如下所示:
SELECT * FROM Name WHERE alias IS NOT NULL AND alias != ""
您还可以将多个参数传递给的单个调用exclude
,以确保仅排除满足所有条件的对象:
Name.objects.exclude(some_field=True, other_field=True)
在这里,some_field
和 other_field
均为true的行被排除在外,因此我们得到两个字段都不为真的所有行。生成的SQL代码看起来像这样:
SELECT * FROM Name WHERE NOT (some_field = TRUE AND other_field = TRUE)
另外,如果您的逻辑比这更复杂,则可以使用Django的Q对象:
from django.db.models import Q
Name.objects.exclude(Q(alias__isnull=True) | Q(alias__exact=''))
顺便说一句:我的SQL示例只是一个类比-实际生成的SQL代码可能看起来有所不同。通过实际查看它们生成的SQL,您将对Django查询的工作方式有更深入的了解。
OR
来融合条件。我将编辑答案以澄清问题。
NOT (A AND B)
等效于NOT A OR NOT B
。我认为这会让熟悉SQL但不熟悉ORM的新Django开发人员感到困惑。
AND
,OR
因为您正在使用,因此利用了将第一个查询中的转换为an的优势exclude
。在一般情况下,将链接视为THEN
,可能更正确exclude(A) THEN exclude(B)
。对不起上面的苛刻语言。您的答案确实不错,但我担心新开发者会过于笼统地接受您的答案。
AND
,并OR
可能是有人从一个SQL后台来Django的有用。为了更深入地了解Django,我认为文档比我能做的更好。
首先,Django文档强烈建议不要对基于字符串的字段(例如CharField或TextField)使用NULL值。阅读说明文件:
https://docs.djangoproject.com/en/dev/ref/models/fields/#null
解决方案:我认为您也可以将QuerySet上的方法链接在一起。尝试这个:
Name.objects.exclude(alias__isnull=True).exclude(alias="")
那应该给您您想要的设置。
为避免使用时出现常见错误exclude
,请记住:
您不能将多个条件添加到exclude()块中filter
。要排除多个条件,必须使用多个exclude()
例
不正确:
User.objects.filter(email='example@example.com')。exclude(profile__nick_name ='',profile__avt ='')
正确的:
User.objects.filter(email='example@example.com')。exclude(profile__nick_name ='')。exclude(profile__avt ='')
您可以简单地做到这一点:
Name.objects.exclude(alias="").exclude(alias=None)
真的就是这么简单。 filter
用于匹配,并且exclude
匹配除指定内容以外的所有内容。这将评估为SQL NOT alias='' AND alias IS NOT NULL
。
alias=""
)和NULL(alias=None
)别名。您的实例将包含带有的实例Name(alias=None)
。
.filter(alias!="")
但不是标题。我已经编辑了答案。但是,字符字段不应允许使用NULL值,而应将空字符串用于非值(按照惯例)。
OR
(仅在这种情况下),它会生成SQLAND
。请参阅此页面以供参考:docs.djangoproject.com/en/dev/topics/db/queries/…链接的优点是可以混合exclude
并filter
为复杂的查询条件建模。如果您想对真实的SQL建模OR
,则必须使用Django Q对象:docs.djangoproject.com/en/dev/topics/db/queries / ... 请编辑您的编辑内容以反映这一点,因为答案很容易引起误解。