【发布时间】:2015-12-16 13:27:27
【问题描述】:
我正在创建一个需要执行日期差异的 Django 应用程序。给定一个在 Postgres 上具有 start_date 和 end_date 的模型,两者都是 DateFields,它的工作原理如下:
model.objects.annotate(difference=F(end_date)-F(start_date))
可以正常工作。但是,在 SQLite 后端,这也不能正常工作。
它返回一个字符串,而不是给出一个 timedelta(或类似的),这大约是年份的差异。但是,SQLite 有一个命令 julianday() 将日期转换为“儒略日”,这至少可以用来计算天数。
例如,在dbshell 上,这将给出正确的天数差异:
SELECT julianday(end_date) - julianday(start_date) FROM 'appname'.'model';
有没有办法:
检查数据库后端 - 例如。是不是 SQLite?
然后,如果是 SQLite,则将其包装在
julianday函数中?
【问题讨论】:
-
你想让
difference成为什么类型? -
时间增量(如果可能)?
-
仅供参考,它与此错误有关,我可能有一个解决方法...code.djangoproject.com/ticket/24793#comment:2
标签: python django postgresql sqlite