数据库迁移Target database is not up to date报错

《flask web 开发》地第十一章做Flask-Migrate数据库迁移时,遇到了Target database is not up to date报错。

按照书上在模型models.py中增加了一个类Post,并且更新了User类。

表增加字段,实现对表结构的更改, 所以这时候会用到Flask-Migrate来创建数据库迁移脚本(执行 python manage.py db migrate),文件夹migrations\versions会有相应的变化,跟着执行 python manage.py db upgrade 把迁移应用到数据库中,更新数据,且不影响其中保存的数据。一切都如期进行。

后来我发现 模型models.py中表Post的字段avatar_hash拼写错了(写成 avatar_user),所以我在Post表中改正过来,再执行 python manage.py db migrate就报错了 Target database is not up to date。

删除 migrations文件夹再 执行 python manage.py db init,之后再 执行 python manage.py db migrate还是一样报错。

gegoole查到在stackoverflow有人曾经提问过:

Alembic stores the db version in a table it creates called alembic_version. This table contains a single field and row alembic_version.version_num. Make sure the value for this matches the filename of the most recent file in migrations/version. This version number is also contained inside the revision file in the revision variable that generally shows up on line 26 of the file. Make sure it matches the db version.

Another option is to simply drop the db and recreate it using alembic. If this is a development environment, where the data is not important, that would be my recommendation.

大概意思是:

  • Alembic 存储数据库表中它会创建名为alembic_version版本。此表包含一个字段和行alembic_version.version_num。确保这个匹配的值最近的文件的文件名在迁移/版本。这个版本号也包含在修改文件的修改变量,通常出现在文件的第26行。确保它匹配的数据库版本。

  • 另一个选择是使用alembic简单地删除db和重新创建它。如果这是一个开发环境,数据并不重要,这是我的建议。

解决:

我直接删除了flasky文件夹中的.sqlite数据库文件和 migrations文件夹,然后执行 python manage.py db init,之后再 执行 python manage.py db migrate,最后 执行python manage.py db upgrade,完美解决没发现问题。
只是数据库中已经注册的用户就清空了,需要重新注册,因为只是在学习练习阶段不用担心数据问题,所以删除是最好的办法。

你可能感兴趣的:(flask)