Django - 查询给出一列不等于同一模型中的另一列的行

时间:2014-01-09 14:14:18

标签: python django django-models django-queryset

我的模型有3个字段

class Table(models.Model):
    in_time = models.DateTimeField(null=True, blank=True) 
    actual_time = models.DateTimeField(null=True, blank=True)

我想以这种方式获取结果:

select * from Table where in_time > '2013-12-31 00:00:00' and in_time != actual_time

所以任何人都可以帮助我完成这个

result = Table.objects.filter(in_time__gte = '2013-12-31 00:00:00')

2 个答案:

答案 0 :(得分:14)

您要搜索的是:

https://docs.djangoproject.com/en/dev/topics/db/queries/#filters-can-reference-fields-on-the-model

<强>解

from django.db.models import F
from datetime import datetime

min_date = datetime(2013,12,31)
result = Table.objects.filter(in_time__gte=min_date).\
exclude(in_time__eq=F('actual_time'))

答案 1 :(得分:4)

使用Q~运算符构建否定(NOT)查询:

import datetime
from django.db.models import Q, F

Table.objects.filter(~Q(in_time=F('actual_time')),
                     in_time__gt=datetime.datetime(2013,12,31))

F引用同一模型上的字段:

  

Django提供F表达式以允许这样的比较。实例   F()充当对查询中的模型字段的引用。这些   然后可以在查询过滤器中使用引用来比较值   同一模型实例上的两个不同字段。