Le flask_sqlalchemy
module n'a pas besoin d'être initialisé avec l'application tout de suite - vous pouvez le faire à la place:
# apps.members.models
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
class Member(db.Model):
# fields here
pass
Et puis dans la configuration de votre application, vous pouvez appeler init_app
:
# apps.application.py
from flask import Flask
from apps.members.models import db
app = Flask(__name__)
# later on
db.init_app(app)
De cette façon, vous pouvez éviter les importations cycliques.
Ce modèle ne nécessite pas de placer tous vos modèles dans un seul fichier. Importez simplement la db
variable dans chacun de vos modules de modèle.
Exemple
# apps.shared.models
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
# apps.members.models
from apps.shared.models import db
class Member(db.Model):
# TODO: Implement this.
pass
# apps.reporting.members
from flask import render_template
from apps.members.models import Member
def report_on_members():
# TODO: Actually use arguments
members = Member.filter(1==1).all()
return render_template("report.html", members=members)
# apps.reporting.routes
from flask import Blueprint
from apps.reporting.members import report_on_members
reporting = Blueprint("reporting", __name__)
reporting.route("/member-report", methods=["GET","POST"])(report_on_members)
# apps.application
from flask import Flask
from apps.shared import db
from apps.reporting.routes import reporting
app = Flask(__name__)
db.init_app(app)
app.register_blueprint(reporting)
Remarque: ceci est une esquisse d'une partie de la puissance que cela vous donne - il y a évidemment beaucoup plus que vous pouvez faire pour rendre le développement encore plus facile (en utilisant un create_app
modèle, des plans à enregistrement automatique dans certains dossiers, etc.)