我有first_name, last_name和别名(可选),我需要搜索。因此,我需要一个查询来给我所有有别名集的名称。
只要我能做到:
Name.objects.filter(alias!="")
那么,与上面的等价的是什么呢?
我有first_name, last_name和别名(可选),我需要搜索。因此,我需要一个查询来给我所有有别名集的名称。
只要我能做到:
Name.objects.filter(alias!="")
那么,与上面的等价的是什么呢?
当前回答
从Django 1.8,
from django.db.models.functions import Length
Name.objects.annotate(alias_length=Length('alias')).filter(alias_length__gt=0)
其他回答
这是另一种简单的方法。
Name.objects.exclude(alias=None)
你可以这样做:
Name.objects.exclude(alias__isnull=True)
如果你需要排除空值和空字符串,首选的方法是像这样将条件链接在一起:
Name.objects.exclude(alias__isnull=True).exclude(alias__exact='')
将这些方法链接在一起基本上是独立地检查每个条件:在上面的例子中,我们排除了别名为null或空字符串的行,因此您得到所有别名字段为非空、非空的Name对象。生成的SQL看起来像这样:
SELECT * FROM Name WHERE alias IS NOT NULL AND alias != ""
你也可以将多个参数传递给一个调用来排除,这将确保只有满足每个条件的对象被排除:
Name.objects.exclude(some_field=True, other_field=True)
这里,some_field和other_field为真的行被排除在外,因此我们得到两个字段都为假的所有行。生成的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=''))
更多信息请参见Django文档中的本页和本页。
顺便说一句:我的SQL示例只是一个类比——实际生成的SQL代码可能看起来不一样。通过实际查看Django查询生成的SQL,您将更深入地了解Django查询是如何工作的。
1. 在使用exclude时,请记住以下内容,以避免常见错误:
不应该像filter()那样在exclude()块中添加多个条件。要排除多个条件,应该使用multiple exclude()。
例子:(不是a也不是b)
Entry.objects.exclude(title='').exclude(headline='')
等于
SELECT... WHERE NOT title = '' AND NOT headline = ''
======================================================
2. 只有在你真正了解它的时候才使用multiple:
示例:NOT (a AND b)
Entry.objects.exclude(title='', headline='')
等于
SELECT.. WHERE NOT (title = '' AND headline = '')
从Django 1.8,
from django.db.models.functions import Length
Name.objects.annotate(alias_length=Length('alias')).filter(alias_length__gt=0)
你可以简单地这样做:
Name.objects.exclude(alias="").exclude(alias=None)
其实就是这么简单。Filter用于匹配,exclude用于匹配除指定内容以外的所有内容。这将在SQL中计算为NOT alias= " AND alias IS NOT NULL。