Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md


KeyError: 'SQLALCHEMY_TRACK_MODIFICATIONS'

關於flask-sqlalchemy中出現的 KeyError: 'SQLALCHEMY_TRACK_MODIFICATIONS'錯誤

image

網上資料都是說因為用了2.2/2.3版本的flask-sqlalchemy的緣故

給出的解決方案都是很扯淡的回退了一下版本,回到2.0.


經過研究 發現原因很顯然不是這樣子 而是代碼從一開始邏輯就不對

研究我們的代碼

app/__init__.py

from flask import Flask app = Flask(__name__) app.debug = True from app.home import home as home_blueprint from app.admin import admin as admin_blueprint app.register_blueprint(home_blueprint) app.register_blueprint(admin_blueprint,url_prefix="/admin") 
app/models.py

from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # 配置數據庫 app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:123456@127.0.0.1:3306/blog" # 如果設置成 True (默認情況),Flask-SQLAlchemy 將會追蹤對象的修改並且發送信號。 app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False # 綁定app至SQLAlchemy db = SQLAlchemy(app) # 會員模型 class User(db.Model): id = db.Column(db.Integer, primary_key=True) ... ... if __name__ == "__main__": db.create_all() 

app/__init__.py 和 app/models.py 中 兩次分別實例化 Flask 類,生成 app 對象

而 app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False 是在模型文件中設置的

但是模型中的 app 對象並不是Flask運行時的 那個 app 對象

只是用來初始化數據庫時臨時用到的 app 對象

所以在訪問頁面的時候會報錯 KeyError: 'SQLALCHEMY_TRACK_MODIFICATIONS'

應該修改成這樣

app/__init__.py

from flask import Flask app = Flask(__name__) app.debug = True from app.home import home as home_blueprint from app.admin import admin as admin_blueprint app.register_blueprint(home_blueprint) app.register_blueprint(admin_blueprint,url_prefix="/admin") # 配置數據庫 app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:123456@127.0.0.1:3306/blog" # 如果設置成 True (默認情況),Flask-SQLAlchemy 將會追蹤對象的修改並且發送信號。 app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False from app.models import db db.init_app(app) 
app/models.py

from flask import Flask from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy() # 會員模型 class User(db.Model): id = db.Column(db.Integer, primary_key=True) ... ... if __name__ == "__main__": app = Flask(__name__) # 配置數據庫 app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:123456@127.0.0.1:3306/blog" # 如果設置成 True (默認情況),Flask-SQLAlchemy 將會追蹤對象的修改並且發送信號。 app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False # 綁定app至SQLAlchemy db = SQLAlchemy(app) db.create_all()


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM