flask 数据库重置迁移

问题描述 投票:0回答:2

我已经为 Flask 应用程序创建了一个数据库,

class Post(db.Model, SearchableMixin):
    __searchable__ = ['body']
    id = db.Column(db.Integer, primary_key=True)
    body = db.Column(db.String(140))
    timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    language = db.Column(db.String(5))
    # for the comment foreign key
    comment = db.relationship('Comment', foreign_keys = 'Comment.post_id', 
        backref = 'post', lazy = 'dynamic')
    photo = db.relationship('Photo', foreign_keys = 'Photo.post_idn', 
        backref = 'post', lazy = 'dynamic')

    def __repr__(self):
        return "<Post {}>".format(self.body)

class Photo(db.Model):
        id = db.Column(db.Integer, primary_key = True)
        user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
        photo_url = db.Column(db.String(200))
        upload_time = db.Column(db.DateTime, index=True, default=datetime.utcnow)
        new_field = db.Column(db.String(100))
        post_id = db.Column(db.Integer, db.ForeignKey('post.id'))

        def __repr__(self):
            return '<Photo {}>'.format(self.photo_url)

当我运行 Flask db 迁移和升级时,它指出

[2018-11-25 21:07:03,439] init中的INFO:微博启动INFO [alembic.runtime.migration] Context impl SQLiteImpl。信息 [alembic.runtime.migration] 将采用非事务性 DDL。

但是,当我尝试在 Flask shell 中运行 Photo.query.all() 时,它给出以下错误“没有这样的列:post_id”

我认为这是一个数据库迁移问题。有人知道我应该做什么吗?

我愿意删除整个数据库并重新迁移所有内容。有人可以建议我该怎么做吗?谢谢。

python database flask database-migration
2个回答
0
投票

您已创建 post_id 作为外键。因此,您必须为 post db 表创建一个 Post 模型,其中包含名为 id 的列。


0
投票

在此发布此内容是为了帮助其他人。

我也遇到了同样的问题,我解决了:

flask 数据库升级

flask 数据库迁移

flask 数据库升级

第一次升级 - 用于应用初始数据库模式、创建表并根据您的 SQLAlchemy 模型定义其结构

Migrate - 用于生成迁移脚本,捕获对数据库架构的任何更改。它还没有应用更改;相反,它准备一个迁移脚本。

第二次升级 - 使用flask db migrate生成迁移脚本后,您可以使用此命令将更改实际应用到数据库。

  • 它执行迁移脚本,其中包含根据模型更改修改数据库架构的 SQL 语句。这会更新数据库以匹配您最新的模型定义。
© www.soinside.com 2019 - 2024. All rights reserved.