python - 将 flask-migrate --multidb 标志放在脚本中的什么位置?
问题描述
我需要将多个数据库添加到我基于Miguel Grinberg 的 Flask Mega-Tutorial的旧版本编写的程序中。我配置了几个数据库SQLALCHEMY_BINDS
并且它们运行良好,但是当我将它们迁移到新版本时问题就来了。我没有得到三个数据库的三个更新版本,而是三个在我的第一个数据库中折叠成三个表。我通过一些研究了解到这是因为 Alembic 感到困惑并将新版本一起混入第一个数据库中,而其余两个保持不变。我知道我需要添加--multidb
标志来解决这个问题。它通常是初始化的一部分:
$ flask db init --multidb
但我想知道我根据他的教程(、、、、)将它放在我拥有的脚本中config.py
的db_create.py
什么db_migrate.py
位置downgrade.py
。我的猜测可能在db_migrate.py
脚本中的某个地方?或者也许是__init__.py
文件?你能给我一个正确的方向吗?谢谢!
迁移.py
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))
__init__.py
from flask import Flask
from flask.ext.socketio import SocketIO, emit
from flask.ext.sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config.from_object('config')
app.config['SECRET_KEY'] = 'shhhhhh!'
socketio = SocketIO(app)
db = SQLAlchemy(app)
from app import views, models
解决方案
本教程的旧版本没有使用 Flask-Migrate,它使用了基于不同于 Alembic 的迁移工具的本土解决方案。您不能真正将 Flask-Migrate/Alembic 放入这些脚本中,它们完全不兼容。
您可以查看本教程的新版本,特别是第 4 章,以了解如何使用 Flask-Migrate。
推荐阅读
- python - 使用已定义和未定义字符拆分字符串
- viber - 如何使按钮的角变圆?振动机器人
- sql - 获取表格尺寸的最快方法?
- html - bootstrap 类 link-dark 不影响
- prometheus - Grafana 中的重复面板
- javascript - 在 Httpresponse 之前或之后调用 ClientScript.RegisterStartupScript 不起作用
- java - 有没有办法改变 jDatePicker 上的按钮颜色
- angular - Angular - 反应式表单:如何正确获取动态和可重用子表单的值
- java - 在 Flux 中生成分页的 WebClient 请求并使用响应
- python - data_arr = pickle.loads(data) EOFError: 用完输入