Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md
Posted String-Lee
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md相关的知识,希望对你有一定的参考价值。
KeyError: ‘SQLALCHEMY_TRACK_MODIFICATIONS‘
关于flask-sqlalchemy
中出现的 KeyError: ‘SQLALCHEMY_TRACK_MODIFICATIONS‘
错误
网上资料都是说因为用了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:[email protected]: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:[email protected]: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:[email protected]:3306/blog"
# 如果设置成 True (默认情况),Flask-SQLAlchemy 将会追踪对象的修改并且发送信号。
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
# 绑定app至SQLAlchemy
db = SQLAlchemy(app)
db.create_all()
以上是关于Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 Flask-SocketIO 修复此 KeyError 错误?
python3 日志检索异常抛出异常 raise KeyError(key),KeyError: 'formatters'