在Django模型QuerySets中,我看到有一个__gt和__lt用于比较值,但是否有__ne或!=(不等于)?我想用一个不等于来过滤掉。例如,对于

Model:
    bool a;
    int x;

我想做的

results = Model.objects.exclude(a=True, x!=5)

!=语法不正确。我也试过__ne。

我最终使用:

results = Model.objects.exclude(a=True, x__lt=5).exclude(a=True, x__gt=5)

当前回答

Django-model-values (disclosure: author)提供了一个NotEqual查找的实现,如下面的答案所示。它还提供了语法支持:

from model_values import F
Model.objects.exclude(F.x != 5, a=True)

其他回答

Django-model-values (disclosure: author)提供了一个NotEqual查找的实现,如下面的答案所示。它还提供了语法支持:

from model_values import F
Model.objects.exclude(F.x != 5, a=True)

您的查询似乎有一个双重否定,您希望排除x不等于5的所有行,所以换句话说,您希望包括x等于5的所有行。我相信这能达到目的:

results = Model.objects.filter(x=5).exclude(a=True)

为了回答你的具体问题,这里没有“not equal To”字段查找,但这可能是因为Django同时提供了过滤和排除方法,所以你可以随时切换逻辑来得到想要的结果。

这会给你想要的结果。

from django.db.models import Q
results = Model.objects.exclude(Q(a=True) & ~Q(x=5))

对于not equal,可以在equal查询上使用~。显然,Q可以用来达到相等的查询。

你可以使用Q对象。它们可以用~操作符求反,并像普通的Python表达式一样组合:

from myapp.models import Entry
from django.db.models import Q

Entry.objects.filter(~Q(id=3))

将返回除ID为3的所有条目:

[<Entry: Entry object>, <Entry: Entry object>, <Entry: Entry object>, ...]

使用排除和过滤

results = Model.objects.filter(x=5).exclude(a=true)