首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLAlchemy DateTime to datetime.datetime

SQLAlchemy DateTime to datetime.datetime
EN

Stack Overflow用户
提问于 2013-07-17 00:49:27
回答 1查看 1.7K关注 0票数 2

如何在SQLAlchemy查询中对DateTime字段和datetime.datetime对象进行比较?

例如,如果我这样做了

代码语言:javascript
复制
candidates = session.query(User).filter_by((User.time - datetime.datetime.utcnow()) > datetime.timedelta(months=2))

我会得到

代码语言:javascript
复制
TypeError: unsupported operand type(s) for -: 'DateTime' and 'datetime.datetime'

我猜这是因为当我们使用filter_by命令时,DateTime字段永远不会被完全提取,因此它不会转换为datetime.datetime对象?这是正确的吗?SQLAlchemy用户通常是如何处理这一问题的?

注意: User.time是一个DateTime字段。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-07-17 03:04:23

首先,请注意datetime.timedelta没有将‘月’作为参数。改为使用'weeks=8‘(http://docs.python.org/2/library/datetime.html#datetime.timedelta)进行尝试。

其次,使用'filter‘而不是'filter_by’,因为后者适用于涉及值查询的更简单的查询(即http://docs.sqlalchemy.org/en/rel_0_8/orm/query.html#sqlalchemy.orm.query.Query.filter=‘Bob’filter)。

所以,我会写成这样:

代码语言:javascript
复制
candidates = session.query(User).filter((User.time - datetime.datetime.utcnow()) > datetime.timedelta(weeks=8))

最后,您的'User‘表的映射是什么,也许问题出在列定义上?

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17682472

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档