0

我对何时更改数据库中的表以匹配 SQLAlchemy 的声明模型中定义的类对象感到困惑。

例如,我有一个commands包含这些字段的表

Command.__table__
Table('commands', MetaData(bind=None), Column('id', Integer(), table=<commands>, primary_key=True, nullable=False), Column('user_id', Integer(), ForeignKey('users.id'), table=<commands>), Column('command_title', String(length=50), table=<commands>), Column('command_desc', String(length=100), table=<commands>), Column('time_added', DateTime(), table=<commands>), Column('time_updated', DateTime(), table=<commands>), Column('favorite', Boolean(), table=<commands>), schema=None)

但是,当我尝试在数据库中添加新行时,SQL 会报错。我认为这是因为我刚刚添加了该列favorite,它尚未反映在数据库中。

错误 :

OperationalError: (OperationalError) table commands has no column named favorite u'INSERT INTO commands (user_id, command_title, command_desc, time_added, time_updated, favorite) VALUES (?, ?, ?, ?, ?, ?)' (2, u'HI', None, None, None, 1)
4

1 回答 1

0

听起来您的数据库可能与您的 model.py 不同步。

快速解决方案是将表语句更改为您的数据库以添加列。我们正在对生产代码使用类似的方法。

即在sqlite中:

ALTER TABLE commands ADD COLUMN favorite BOOLEAN;

或从配置了 SQLAlchemy 引擎的 python:

engine.execute("ALTER TABLE commands ADD COLUMN favorite BOOLEAN")

我用于另一个项目的替代方法 -engine.create_all()每次更改 model.py 时,我都会使用 sqlalchemy 创建数据库模式。然后加载测试数据——但这对于包含生产数据的数据库来说是乏味的。

迁移可能是一种方式( SQLAlchemy 的Alembic模块以与数据库无关的方式执行此操作)。但是编写数据迁移需要一些努力,并且在相对较大的项目中是值得的。

于 2013-05-02T20:33:30.670 回答