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

当前回答

虽然你可以用=,__gt, __gte, __lt, __lte来过滤模型,但你不能使用ne或!=。但是,您可以使用Q对象实现更好的过滤。

你可以避免链接QuerySet.filter()和QuerySet.exclude(),并使用以下方法:

from django.db.models import Q
object_list = QuerySet.filter(~Q(field='not wanted'), field='wanted')

其他回答

创建一个自定义查找很容易,在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)

results = Model.objects。filter(a = True)。生成sql: select * from tablex where a != 0 and x !=5 sql取决于True/False字段的表示方式,以及数据库引擎。django代码是你所需要的。

查询中的field=value语法是field__exact=value的缩写。也就是说,Django将查询操作符放在标识符中的查询字段上。Django支持以下操作符:

exact
iexact
contains
icontains
in
gt
gte
lt
lte
startswith
istartswith
endswith
iendswith
range

date
year
iso_year
month
day
week
week_day
iso_week_day
quarter
time
hour
minute
second

isnull
regex
iregex

我相信,通过像Dave Vogt建议的那样将这些对象与Q对象结合起来,并像Jason Baker建议的那样使用filter()或exclude(),您将得到几乎任何可能的查询所需要的东西。

你应该像这样使用过滤和排除

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

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

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

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