Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 在sqlalchemy中使用DATEADD_Python_Sql_Sqlalchemy_Flask_Flask Sqlalchemy - Fatal编程技术网

Python 在sqlalchemy中使用DATEADD

Python 在sqlalchemy中使用DATEADD,python,sql,sqlalchemy,flask,flask-sqlalchemy,Python,Sql,Sqlalchemy,Flask,Flask Sqlalchemy,如何使用python中的sqlalchemy重写以下sql语句。我已经搜索了30分钟,但仍然找不到任何解决方案 DATEADD(NOW(), INTERVAL 1 DAY) 或 提前感谢SQLAlchemy日期自动映射到Python datetime对象,因此您应该能够: from sqlalchemy import Table, Column, MetaData, DateTime from datetime import datetime, timedelta metadata = Me

如何使用python中的sqlalchemy重写以下sql语句。我已经搜索了30分钟,但仍然找不到任何解决方案

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在我打字时击败了我,这里有一个烧瓶sqlalchemy示例,我要发布它(为了补充简单的sqlalchemy示例):

您也可以将默认值作为可调用项传递:

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:

其结果是:

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

您可以使用MySQL
timestampadd
insted
dateadd


更详细的信息

不幸的是,SQLAlchemy的日期系统现在不会自动强制执行特定于平台的函数,如DATEADD()。只有在带有psycopg2的Postgresql(可能还有mysql)上,上述简单的日期算法才能转化为DB所期望的。值得注意的是,这只适用于某些DBs&这些DBs可能需要
text
版本。@wbyoung:因为OP说明了他们想在问题中使用的确切SQL表达式,可以安全地假设他们使用的数据库支持语法。其他数据库支持
DATEADD(NOW(),INTERVAL 1 DAY)
,即MySQL,但SQLAlchemy不支持,因为适配器的类型有问题。
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)
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)'
from sqlalchemy.sql import func
from sqlalchemy.sql.expression import text

tomorrow = func.dateadd(func.now(), text('interval 1 day'))
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()