码迷,mamicode.com
首页 > 数据库 > 详细

Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md

时间:2018-12-04 00:10:11      阅读:436      评论:0      收藏:0      [点我收藏+]

标签:source   imageview   RoCE   use   https   ==   ima   als   技术   

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: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()

Flask報錯 KeyError 'SQLALCHEMY_TRACK_MODIFICATIONS'.md

标签:source   imageview   RoCE   use   https   ==   ima   als   技术   

原文地址:https://www.cnblogs.com/String-Lee/p/10061675.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!