Flask-Migrateを使用したいのですが、その例を見ています:
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
from flask.ext.script import Manager
from flask.ext.migrate import Migrate, MigrateCommand
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///app.db'
db = SQLAlchemy(app)
migrate = Migrate(app, db)
manager = Manager(app)
manager.add_command('db', MigrateCommand)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(128))
if __name__ == '__main__':
manager.run()
これは単純な play の例としてはうまく機能しますが、モデルが複数あるため、このスクリプトとアプリケーション コードを定義するスクリプトの両方でモデルを定義したくありません。したがって、2 つの間で共有できるモデル ファイルにそれらを取り込みたいと考えています。
User
クラスをに配置しmodels.py
、そこから User をインポートすることで、これを実行しようとしています。残念ながら、それはNameError: name 'db' is not defined
.
私の質問は次のとおりです。
db = SQLAlchemy(app)
で使用する必要がありmodels.py
ますか? もしそうなら、これは移行スクリプトとフラスコ アプリケーション自体の両方で利用できますか?- に入れられない (または入れるべきではない) 場合、
models.py
自分のモデルを独自のファイルで使用する方法を教えてくださいdb
。