Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/python-3.x/18.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 对多个文件中的模型使用Flask migrate_Python_Python 3.x_Flask_Flask Sqlalchemy_Flask Migrate - Fatal编程技术网

Python 对多个文件中的模型使用Flask migrate

Python 对多个文件中的模型使用Flask migrate,python,python-3.x,flask,flask-sqlalchemy,flask-migrate,Python,Python 3.x,Flask,Flask Sqlalchemy,Flask Migrate,当我有多个模型时,我对如何使用Flask Migrate感到困惑。 基本上,我的Flask应用程序如下所示: app ├── __init__.py ├── config.py ├── manage.py ├── migrations ├── models │   ├── model1.py │   ├── model2.py ├── resources ├── run.py └── tests 我发现,对于每个模型,最好在文件中创建db=SQLAlchemy()对象,然后将此db对象导入应用

当我有多个模型时,我对如何使用Flask Migrate感到困惑。 基本上,我的Flask应用程序如下所示:

app
├── __init__.py
├── config.py
├── manage.py
├── migrations
├── models
│   ├── model1.py
│   ├── model2.py
├── resources
├── run.py
└── tests
我发现,对于每个模型,最好在文件中创建
db=SQLAlchemy()
对象,然后将此db对象导入应用程序的
\uuuuu init\uuuuuuuuuuuy.py
,如下所示:

from models.model1 import db
db.init_app(app)
from models.model2 import db
db.init_app(app)
但是,如果我对多个模型文件执行此操作,我如何添加Flasks的迁移功能,因为我只能使用1个sql alchemy对象进行迁移类实例化:

migrate = Migrate(app, db)
manager = Manager(app)
manager.add_command('db', MigrateCommand)

在这种情况下,最好在
\uuuu init\uuuuu.py
文件中定义一个sql alchemy对象并将其导入到我的所有模型中

您误读了引用的文本。这谈的是完全不同的事情。这涉及到将您的
db
对象与
app
对象分开(并在
create\u app
factory函数中将二者结合在一起)。创建多个
db
对象只会使事情变得复杂

所需的只是一个单个
db=SQLAlchemy()
对象,所有定义模型的文件都需要导入。通常通过
create_app
工厂函数直接或间接完成,您需要调用
create_app()
函数才能运行
flask db
命令行工具

接下来,您也不需要创建管理器。
Managar
对象是Flask项目添加脚本本身支持之前的遗留对象。如果您使用的是Flask 0.12或更新版本,则不希望使用Flask脚本及其管理器

因此,在您的
\uu init\upy.py
中,您所需要的是:

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate


db = SQLAlchemy()


def create_app(test_config=None):
    app = Flask(__name__)

    app.config.from_object(f"{__name__}.config")
    app.config.from_envvar("PROJECTNAME_SETTINGS", silent=True)
    if test_config:
        app.config.from_mapping(test_config)

    db.init_app(app)
    Migrate(app, db)

    # importing the models to make sure they are known to Flask-Migrate
    from models import models1, models2

    # any other registrations; blueprints, template utilities, commands

    return app