如何在python中用sqlalchemy重寫以下sql語句。我一直在尋找30分鐘,但仍找不到任何解決方案。在sqlalchemy中使用DATEADD
DATEADD(NOW(), INTERVAL 1 DAY)
或
INSERT INTO dates (expire)
VALUES(DATEADD(NOW(), INTERVAL 1 DAY))
在此先感謝
如何在python中用sqlalchemy重寫以下sql語句。我一直在尋找30分鐘,但仍找不到任何解決方案。在sqlalchemy中使用DATEADD
DATEADD(NOW(), INTERVAL 1 DAY)
或
INSERT INTO dates (expire)
VALUES(DATEADD(NOW(), INTERVAL 1 DAY))
在此先感謝
SQLAlchemy的日期自動地映射到Python datetime對象,所以你應該能夠做到:
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)
Doobeh打我當我打字的時候,這是一個我將要發佈的flask-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)
爲了完整起見,這裏是你將怎樣生成精確的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'))
值得注意的是[文檔聲明'Interval'](http://docs.sqlalchemy.org/en/latest/core/type_basics.html#sqlalchemy.types.Interval)只適用於某些數據庫和文本'版本可能需要這些。 – wbyoung 2016-11-18 20:56:28
@wbyoung:由於OP聲明瞭他們想要在問題中使用的確切的SQL表達式,因此假設他們正在使用支持該語法的數據庫是安全的。 – 2016-11-18 20:57:47
其他數據庫支持'DATEADD(NOW(),INTERVAL 1 DAY)',即MySQL,但SQLAlchemy不支持,因爲適配器有類型問題。 – wbyoung 2016-11-19 00:38:26
您可以使用MySQL timestampadd
insted的dateadd
。
更多細節http://dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_timestampadd
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()
不幸的SQLAlchemy的日期系統不會自動強制到像DATEADD特定平臺funcitons()現在。只有在psycopg2(也可能是mysql)上的Postgresql上面有簡單的日期算法才能轉化爲DB的期望。 – zzzeek 2013-03-23 00:03:50