Dla dobra kompletności, tutaj jest jak chcesz wygenerować dokładnie to SQL z wykorzystaniem sqlalchemy.sql.func
:
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()))
co skutkuje:
>>> 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)'
Alternatywnie można użyć text()
obiektu, aby określić przedział zamiast:
from sqlalchemy.sql import func
from sqlalchemy.sql.expression import text
tomorrow = func.dateadd(func.now(), text('interval 1 day'))
niestety System data sqlalchemy nie będzie automatycznie zmusić do platformy konkretnych funcitons jak DateAdd() teraz. Tylko na Postgresql z psycopg2 (i może także mysql) wykonuje prostą arytmetyczną datę jak powyżej, tłumacząc to, czego oczekuje DB. – zzzeek