zoukankan      html  css  js  c++  java
  • 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()
  • 相关阅读:
    bzoj4537: [Hnoi2016]最小公倍数
    bzoj4331: JSOI2012 越狱老虎桥
    bzoj4558: [JLoi2016]方
    bzoj4209: 西瓜王
    bzoj2653: middle
    bzoj4671: 异或图
    bzoj4771: 七彩树
    shell java应用启动脚本(app.sh)
    Springboot 构建http服务,返回的http行是'HTTP/1.1 200' 无状态码描述 客户端解析错误
    MariaDB(Mysql)-主从搭建
  • 原文地址:https://www.cnblogs.com/String-Lee/p/10061675.html
Copyright © 2011-2022 走看看