【问题标题】:alembic: create relationship in revision filealembic:在修订文件中创建关系
【发布时间】:2015-03-22 09:49:18
【问题描述】:

我需要通过向现有表添加一张表和一列来更新我的数据库。 新列和表应该是一对多的关系。

这是alembic修订文件:

def upgrade():
    op.create_table('categories',
        sa.Column('category_id', sa.Integer, primary_key=True),
        sa.Column('category_name', sa.String(30)),
        sa.Relationship('post', backref='cat', lazy='dynamic') )
    op.add_column('post', sa.Column('category', sa.Integer, sa.ForeignKey('categories.category_id')) )

问题出在这一行:

sa.Relationship('post', backref='cat', lazy='dynamic') )

在这里定义关系的正确代码是什么? 谢谢你

【问题讨论】:

  • Alembic 是一个数据库迁移工具,因此它不关心关系。它确实处理ForeignKeys。所以你不应该用它来迁移关系定义,你只把它放到你的模型中。

标签: flask sqlalchemy alembic


【解决方案1】:

关系仅在 SQLAlchemy 端定义,而不在 SQL 端定义。只需创建您需要的表或列,关系就会正常工作。因此,它不应该在迁移中。

【讨论】:

    猜你喜欢
    • 2020-11-17
    • 1970-01-01
    • 1970-01-01
    • 2021-02-28
    • 2017-03-23
    • 2015-01-15
    • 1970-01-01
    • 2014-04-16
    • 1970-01-01
    相关资源
    最近更新 更多