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()
  • 相关阅读:
    win10 UWP button
    内网分享资源
    内网分享资源
    CF724F Uniformly Branched Trees
    win10 UWP FlipView
    win10 UWP FlipView
    win10 UWP FlipView
    搭建阿里云 centos mysql tomcat jdk
    搭建阿里云 centos mysql tomcat jdk
    win10 UWP 申请微软开发者
  • 原文地址:https://www.cnblogs.com/String-Lee/p/10061675.html
Copyright © 2011-2022 走看看