14

Pythonでsqlalchemyを使用して次のSQLステートメントを書き直すにはどうすればよいですか?私は30分を探していましたが、それでも解決策を見つけることができませんでした。

DATEADD(NOW(), INTERVAL 1 DAY)

また

INSERT INTO dates (expire)
VALUES(DATEADD(NOW(), INTERVAL 1 DAY))

前もって感謝します

4

5 に答える 5

37

完全を期すために、以下を使用して正確なSQLを生成する方法を次に示します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()))

その結果:

>>> 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)'

text()または、オブジェクトを使用して間隔を指定することもできます。

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

tomorrow = func.dateadd(func.now(), text('interval 1 day'))
于 2013-03-22T15:12:10.417 に答える
9

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)
于 2013-03-22T15:02:14.293 に答える
3

私がタイプしている間、Doobehは私をそれに打ち負かしました、これは私が投稿しようとしていたフラスコ-sqlalchemyの例です(プレーンなsqlalchemyの例を補完するために):

from flask.ext.sqlalchemy import SQLAlchemy
from datetime import datetime, timedelta

db = SQLAlchemy()

class Thing(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    created = db.Column(db.DateTime)

c = Thing(created = datetime.utcnow() + timedelta(days=1))
print repr(c.created)
# datetime.datetime(2013, 3, 23, 15, 5, 48, 136583)

デフォルトを呼び出し可能として渡すこともできます。

from flask.ext.sqlalchemy import SQLAlchemy
from datetime import datetime, timedelta

db = SQLAlchemy()

def tomorrow():
    return datetime.utcnow() + timedelta(days=1)

class Thing(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    publish_date = db.Column(db.DateTime, default=tomorrow)
于 2013-03-22T15:06:16.750 に答える
0

timestampaddMySQLinstedを使用できますdateadd

詳細http://dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_timestampadd

于 2016-08-26T00:16:10.907 に答える
0
from datetime import datetime, timedelta
from dateutil import tz

new_date = datetime.now(tz=tz.tzlocal()) + timedelta(days=1)
new_item = Expire(expire=new_date)
session.save(new_item)
session.commit()
于 2016-12-29T21:20:35.943 に答える