在sqlalchemy中使用DATEADD

Alp*_*per 7 python sql sqlalchemy flask flask-sqlalchemy

如何在python中使用sqlalchemy重写以下sql语句.我一直在寻找30分钟,但仍然找不到任何解决方案.

DATEADD(NOW(), INTERVAL 1 DAY)
Run Code Online (Sandbox Code Playgroud)

要么

INSERT INTO dates (expire)
VALUES(DATEADD(NOW(), INTERVAL 1 DAY))
Run Code Online (Sandbox Code Playgroud)

提前致谢

Mar*_*ers 24

为了完整起见,以下是使用sqlalchemy.sql.func以下方法生成精确SQL的方法:

from sqlalchemy.sql import func
from sqlalchemy.sql.expression import bindparam
from sqlalchemy import Interval

tomorrow = func.dateadd(func.now(), bindparam('tomorrow', timedelta(days=1), Interval()))
Run Code Online (Sandbox Code Playgroud)

这导致:

>>> from sqlalchemy.sql import func
>>> func.dateadd(func.now(), bindparam('tomorrow', timedelta(days=1), Interval(native=True)))
<sqlalchemy.sql.expression.Function at 0x100f559d0; dateadd>
>>> str(func.dateadd(func.now(), bindparam('tomorrow', timedelta(days=1), Interval(native=True))))
'dateadd(now(), :tomorrow)'
Run Code Online (Sandbox Code Playgroud)

或者,您可以使用text()对象来指定间隔:

from sqlalchemy.sql import func
from sqlalchemy.sql.expression import text

tomorrow = func.dateadd(func.now(), text('interval 1 day'))
Run Code Online (Sandbox Code Playgroud)

  • 值得注意的是,[文档指出“Interval”](http://docs.sqlalchemy.org/en/latest/core/type_basics.html#sqlalchemy.types.Interval)仅适用于某些数据库和“文本”这些可能需要版本。 (2认同)
  • @wbyoung:由于OP声明了他们想要在问题中使用的确切SQL表达式,因此可以安全地假设他们正在使用支持该语法的数据库。 (2认同)
  • 其他数据库支持“DATEADD(NOW(), INTERVAL 1 DAY)”,即 MySQL,但 SQLAlchemy 不支持,因为适配器存在类型问题。 (2认同)

Doo*_*beh 7

SQLAlchemy日期自动映射到Python日期时间对象,因此您应该能够:

from sqlalchemy import Table, Column, MetaData, DateTime
from datetime import datetime, timedelta

metadata = MetaData()
example = Table('users', metadata,
   Column('expire', DateTime)
)

tomorrow = datetime.now() + timedelta(days=1)

ins = example.insert().values(expire=tomorrow)
Run Code Online (Sandbox Code Playgroud)

  • 不幸的是,SQLAlchemy的日期系统现在不会自动强制转换为特定于平台的功能,如DATEADD().仅在带有psycopg2的Postgresql(也可能是mysql)上,如上所述的简单日期算法转换为DB期望的内容. (3认同)