在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)

当前回答

注意这个问题有很多错误的答案!

Gerard的逻辑是正确的,尽管它将返回一个列表而不是一个查询集(这可能无关紧要)。

如果你需要一个queryset,使用Q:

from django.db.models import Q
results = Model.objects.filter(Q(a=false) | Q(x=5))

其他回答

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

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

这会给你想要的结果。

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

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

您要寻找的是所有具有a=false或x=5的对象。在Django中,|作为查询集之间的OR运算符:

results = Model.objects.filter(a=false)|Model.objects.filter(x=5)

创建一个自定义查找很容易,在Django的官方文档中有一个__ne查找的例子。

你需要先创建查找本身:

from django.db.models import Lookup

class NotEqual(Lookup):
    lookup_name = 'ne'

    def as_sql(self, compiler, connection):
        lhs, lhs_params = self.process_lhs(compiler, connection)
        rhs, rhs_params = self.process_rhs(compiler, connection)
        params = lhs_params + rhs_params
        return '%s <> %s' % (lhs, rhs), params

然后你需要注册它:

from django.db.models import Field
Field.register_lookup(NotEqual)

现在你可以像这样在你的查询中使用__ne查找:

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

注意这个问题有很多错误的答案!

Gerard的逻辑是正确的,尽管它将返回一个列表而不是一个查询集(这可能无关紧要)。

如果你需要一个queryset,使用Q:

from django.db.models import Q
results = Model.objects.filter(Q(a=false) | Q(x=5))