我正在尝试在 Django 中执行与以下 SQL 等效的操作:
SELECT * FROM applicant WHERE date_out - date_in >= 1 AND date_out - date_in <= 6
我可以将其作为 RAW sql 查询来执行,但这在处理 RawQuerySet 而不是常规 QuerySet 对象时变得令人沮丧,因为我希望稍后能够在代码中对其进行过滤。
您可以使用该extra()
方法并传入where
关键字参数。的值where
应该是一个包含WHERE
上述查询的 SQL 子句的列表。我用 Postgresql 8.4 对此进行了测试,这就是我的情况:
q = Applicant.objects.extra(where = ["""date_part('day', age(date_out, date_in)) >= 1 and
date_part('day', age(date_out, date_in)) <= 6"""])
这将为您返回一个有效的QuerySet
实例。
我遇到了 Django 本身不支持Datediff
(和其他数据库等价物)的问题,并且需要在特定项目中多次使用这样的功能。
进一步阅读后,很明显从两个日期计算间隔的实现在主要数据库风格之间存在很大差异。这可能就是为什么它在 Django 中还没有原生抽象函数的原因。所以我写了我自己的 Django ORM 函数datediff
:
您将看到在各个数据库的文档字符串中编写的数据库后端之间的不同语法。Datediff 支持 sqlite、MySQL/MariaDB、PostgreSQL 和 Oracle。
用法(Django 1.8+):
from db_tools import Datediff
# Define a new dynamic fields to contain the calculated date difference
applicants = Applicant.objects.annotate(
days_range=Datediff('date_out','date_in', interval='days'),
)
# Now you can use this dynamic field in your standard filter query
applicants = applicants.filter(days_range__gte=1, days_range__lte=6)
当谈到我的代码时,我真的很愚蠢,所以我鼓励你分叉和改进。