SQL Alchemy 更新时间在 Alembic 修订版中不起作用

SQL Alchemy update time not working in Alembic revision

我在 update_time 的 alembic 修订版中有一个列,以显示更新列的时间。

目前我尝试过:

sa.Column('update_time', sa.dialects.mysql.DATETIME(fsp=3), nullable=False, server_default=str(datetime.utcnow()), onupdate=str(datetime.utcnow()), server_onupdate=str(datetime.utcnow()))

我也试过:

sa.Column('test_time', sa.DateTime(), server_default=sa.func.now(), server_onupdate=sa.func.now(), onupdate=sa.func.now())

构建数据库时,获取 utcnow() 时间作为 DateTime。

但是,当我在 mysql 中通过命令行更新列时,该列保持相同的时间戳。

如何获取要更新的时间戳?

可以使用:

from sqlalchemy import text
from sqlalchemy.dialects.mysql import TIMESTAMP

sa.Column('update_time', TIMESTAMP(), nullable=False, server_default=text('CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP'))