这是我的声明性模型:

import datetime
from sqlalchemy import Column, Integer, DateTime
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class Test(Base):
    __tablename__ = 'test'

    id = Column(Integer, primary_key=True)
    created_date = DateTime(default=datetime.datetime.utcnow)

然而,当我试图导入这个模块时,我得到这个错误:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "orm/models2.py", line 37, in <module>
    class Test(Base):
  File "orm/models2.py", line 41, in Test
    created_date = sqlalchemy.DateTime(default=datetime.datetime.utcnow)
TypeError: __init__() got an unexpected keyword argument 'default'

如果我使用Integer类型,我可以设置默认值。这是怎么呢


当前回答

您也可以为默认的DateTime使用sqlalchemy内置函数

from sqlalchemy.sql import func

DT = Column(DateTime(timezone=True), default=func.now())

其他回答

您也可以为默认的DateTime使用sqlalchemy内置函数

from sqlalchemy.sql import func

DT = Column(DateTime(timezone=True), default=func.now())

使用默认参数datetime.now:

from sqlalchemy import Column, Integer, DateTime
from datetime import datetime
class Test(Base):
     __tablename__ = 'test'
     id = Column(Integer, primary_key=True)
     created_at = Column(DateTime, default=datetime.now)
     updated_at = Column(DateTime, default=datetime.now, onupdate=datetime.now)                                                            

Jeff Widman在他的回答中说,您需要为funct .utcnow()创建自己的UTC时间戳实现。

因为我不想自己实现它,我已经搜索并找到了一个python包,它已经完成了这项工作,并由许多人维护。

包名为spoqa/sqlalchemy-ut。

这个包的功能总结如下: 长话短说,UtcDateTime做:

只取有意识的datetime.datetime, 只返回感知的datetime。 永远不要接受或返回naive datetime.datetime, 确保数据库中的时间戳始终以UTC编码,并且 按照你期望的方式工作。

对于mariadb,这对我来说是有效的:

from sqlalchemy import Column, Integer, String, DateTime, TIMESTAMP, text
from sqlalchemy.sql import func
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class Test(Base):
  __tablename__ = "test"

  id              = Column(Integer, primary_key=True, autoincrement=True)
  name            = Column(String(255), nullable=False)
  email           = Column(String(255), nullable=False)
  created_at      = Column(TIMESTAMP, nullable=False, server_default=func.now())
  updated_at      = Column(DateTime, server_default=text("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP"))

在mariadb的sqlalchemy文档中,建议从sqlalchemy本身导入文本,并使用文本设置server_default,插入自定义命令。

updated_at=Column(DateTime, server_default=text("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP"))

要理解func。现在可以阅读SQL alchemy文档了。

希望我能帮上忙。

根据PostgreSQL文档:

现在,CURRENT_TIMESTAMP, LOCALTIMESTAMP返回事务的时间

这被认为是一个特性:目的是允许单个 事务要对“当前”时间有一致的概念,这样才能做到 同一事务中的多个修改具有相同的时间戳。

如果不想使用事务时间戳,可能需要使用statement_timestamp或clock_timestamp。

statement_timestamp ()

返回当前语句的开始时间(更具体地说, 从客户端接收最新命令消息的时间)。 statement_timestamp

clock_timestamp ()

返回实际的当前时间,因此它的值甚至会改变 在一个SQL命令中。