У меня следующая структура проекта:
Проект / __ __ INIT. Ру
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
db = SQLAlchemy()
migrate = Migrate()
def create_app():
app = Flask(__name__)
app.config.from_object(os.environ['APP_SETTINGS'])
db.init_app(app)
migrate.init_app(app, db)
return app
run.py
from project import create_app
app = create_app()
if __name__ == "__main__":
app.run()
manage.py
from flask_script import Manager
from flask_migrate import MigrateCommand
from project.models import *
from project import create_app
manager = Manager(create_app)
manager.add_command('db', MigrateCommand)
if __name__ == '__main__':
manager.run()
Тем не менее, когда я запускаю следующие команды, Flask-Migrate не обнаруживает добавляемых таблиц.
python manage.py db init
Какие выходы:
Creating directory $HOME/Project/migrations ... done
Creating directory $HOME/Project/migrations/versions ... done
Generating $HOME/Project/migrations/script.py.mako ... done
Generating $HOME/Project/migrations/env.py ... done
Generating $HOME/Project/migrations/README ... done
Generating $HOME/Project/migrations/alembic.ini ... done
Please edit configuration/connection/logging settings in
'$HOME/Project/migrations/alembic.ini' before proceeding.
и
python manage.py db migrate
Который только выводит:
INFO [alembic.runtime.migration] Context impl PostgresqlImpl.
INFO [alembic.runtime.migration] Will assume transactional DDL.
Почему Flask-Migrate с Alembic не обнаруживает Модели и, следовательно, не создает таблицы? Вот что я попробовал:
- Удаление базы данных, начиная с нуля
- Создание собственного класса БД внутри файла manage.py, не обнаруживает это
- Погуглив каждый ответ на эту проблему, нашел много похожих вопросов, но ни одно из их решений не помогло мне.
EDIT:
Вот пример файла models.py
from flask import current_app
from project import db
from flask_login import UserMixin
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(50))