gpt4 book ai didi

python - 将数据库迁移从 sqlalchemy-migrate 更改为 Flask-Migrate

转载 作者:太空宇宙 更新时间:2023-11-03 13:16:34 31 4
gpt4 key购买 nike

我有一个基于 miguel flask tutorial 的网络应用程序

所以我将 sqlalchemy-migrate 用于数据库,现在我应该在迁移中使用 Alembic 我该如何配置?有什么方法可以让我从 sqlalchemy-migrate 更改为 Flask-Migrate?(因为我的应用程序已经完成,再做一遍又是很多工作)谢谢

db_migrate.py :

#!flask/bin/python
import imp
from migrate.versioning import api
from app import db
from config import SQLALCHEMY_DATABASE_URI
from config import SQLALCHEMY_MIGRATE_REPO
migration = SQLALCHEMY_MIGRATE_REPO + '/versions/%03d_migration.py' % (api.db_version(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO) + 1)
tmp_module = imp.new_module('old_model')
old_model = api.create_model(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
exec old_model in tmp_module.__dict__
script = api.make_update_script_for_model(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO, tmp_module.meta, db.metadata)
open(migration, "wt").write(script)
api.upgrade(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
print 'New migration saved as ' + migration
print 'Current database version: ' + str(api.db_version(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO))

最佳答案

有三种可能的方法来处理这个问题,其中两种相对容易,但最后一种非常费力:

1。仅使用 Flask-Migrate 跟踪 future 的迁移

这是最简单的,但没那么有趣。只需像为新项目一样安装和设置 Flask-Migrate,下次需要迁移时,使用它而不是 sqlalchemy-migrate。

缺点是迁移的当前状态不会被 Alembic 记录,只有您将来应用的迁移才会被记录。

2。跟踪数据库的当前状态作为单个初始迁移

这改进了以前的方法并使 Flask-Migrate 的存储库完整,但是您在 sqlalchemy-migrate 中的所有迁移都合并为一个 Alembic 迁移。

过程如下:

  • 创建 Flask-Migrate 存储库
  • 备份数据库中的数据,如果你在意的话(你会在下一步中丢失它!)
  • 使用教程中的 db_downgrade.py 脚本,将您的数据库设置为版本 0(空数据库)。
  • 使用 Flask-Migrate 生成迁移。此迁移将包括您当前版本之前的所有数据库更改。
  • 将数据恢复到您的数据库。
  • 正常使用 Flask-Migrate 应用 future 的迁移。您可以删除 sqlalchemy-migrate 存储库,因为所有数据库更改现在都在 Alembic 中。

3。将整个迁移历史转移到 Flask-Migrate

这是最复杂的解决方案,因为它需要将您在 sqlalchemy-migrate 中的每一次迁移都单独传输到 Alembic。

过程如下:

  • 创建 Flask-Migrate 存储库
  • 备份数据库中的数据,如果你在意的话(你会在下一步中丢失它!)
  • 使用教程中的 db_downgrade.py 脚本,将您的数据库设置为版本 0(空数据库)。或者,如果更简单,只需手动删除数据库中的所有表。
  • 假设您的应用程序采用源代码控制,请检查与您的第一次数据库迁移相匹配的代码版本。
  • 使用 Flask-Migrate 生成迁移。此迁移将与您的第一个 sqlalchemy-migrate 迁移相同。
  • 检查与第二个 sqlalchemy-migrate 迁移匹配的代码版本。
  • 使用 Flask-Migrate 生成第二个迁移。此迁移将与您的第二个 sqlalchemy-migrate 迁移相同。
  • 以此类推,直到到达当前代码版本和上次数据库迁移。
  • 将数据恢复到您的数据库。
  • 正常使用 Flask-Migrate 应用 future 的迁移。您可以删除 sqlalchemy-migrate 存储库,因为所有数据库更改现在都在 Alembic 中。

如果您需要推荐,我认为在大多数情况下,#2 是最佳选择。如果我预计我需要将我的数据库降级到历史上的特定迁移,我只会经历 #3 的痛苦。

关于python - 将数据库迁移从 sqlalchemy-migrate 更改为 Flask-Migrate,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28135936/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com