如何在SQLAlchemy查询中对DateTime字段和datetime.datetime对象进行比较?
例如,如果我这样做了
candidates = session.query(User).filter_by((User.time - datetime.datetime.utcnow()) > datetime.timedelta(months=2))我会得到
TypeError: unsupported operand type(s) for -: 'DateTime' and 'datetime.datetime'我猜这是因为当我们使用filter_by命令时,DateTime字段永远不会被完全提取,因此它不会转换为datetime.datetime对象?这是正确的吗?SQLAlchemy用户通常是如何处理这一问题的?
注意: User.time是一个DateTime字段。
发布于 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)。
所以,我会写成这样:
candidates = session.query(User).filter((User.time - datetime.datetime.utcnow()) > datetime.timedelta(weeks=8))最后,您的'User‘表的映射是什么,也许问题出在列定义上?
https://stackoverflow.com/questions/17682472
复制相似问题