python - 从 RDS 检索数据给出 AttributeError : 'sqlalchemy.cimmutabledict.immutabledict' object has no attribute 'setdefault'

标签 python mysql flask flask-sqlalchemy attributeerror

我想在 API 端点 {{url}}/api/users/login 时从 RDS 检索用户数据被调用以对用户进行身份验证,但是,我目前在从 RDS 检索数据时遇到问题。
错误堆栈跟踪
这是错误的完整堆栈跟踪:
enter image description here
当前包版本

Flask==1.1.2
Flask-Cors==3.0.10
flask-marshmallow==0.14.0
Flask-Migrate==2.5.3
Flask-RESTful==0.3.8
Flask-SQLAlchemy==2.4.4
marshmallow==3.10.0
marshmallow-sqlalchemy==0.24.1
SQLAlchemy==1.4.0b1
python==3.7
我解决问题的尝试
我试图解决问题但无济于事的一些事情是:
  • 使用 pymysql 连接器代替 mysqlconnector
  • 降级 flask 棉花糖==0.11.0
  • 降级棉花糖==3.6.1
  • 降级棉花糖-sqlalchemy==0.23.1

  • 有关我的应用程序设置的更多信息
    我已经 Dockerized 我的应用程序,这是我当前的设置:
    app.py
    from flask_marshmallow import Marshmallow
    from flask_migrate import Migrate
    from flask_sqlalchemy import SQLAlchemy
    from flask_jwt_extended import JWTManager
    
    db = SQLAlchemy()
    ma = Marshmallow()
    migrate = Migrate()
    
    def register_extensions(app: Flask) -> None:
       db.init_app(app)
       migrate.init_app(app, db)
       ma.init_app(app)
    
    def create_application() -> Flask:
       app: Flask = Flask(__name__)
       app.config['SQLALCHEMY_DATABASE_URI'] = "mysql+mysqlconnector://{DB_USER}:{DB_PASSWORD}@{DB_INSTANCE}:{DB_PORT}"
       app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
       register_extensions(app)
       app.register_blueprint(users_urls.mod, url_prefix=f"/{BEP_PREFIX}/users")
    
       return app
    
     app = create_application()
     CORS(app)
    
    模型.py
    class Accounts(db.Model):
        __tablename__ = 'Accounts'
        username = db.Column(db.String(100), primary_key=True)
        password = db.Column(db.String(256), nullable=False)
        email = db.Column(db.String(255), nullable=False)
        personnelID = db.Column(db.String(255), nullable=False)
        userType = db.Column(db.String(45), nullable=False)
    
    service.py
    class UserService(Service):
        __model__ = Accounts
    
        def get(self, username):
            return Accounts.query.filter_by(username=username).first()
    
    user_service = UserService()
    
    View .py
    from bep.users.services import user_service
    
    class UserLogin(Resource):
       def post(self):
           data = request.get_json()
    
           try:
               userData = user_service.get("test")
           except Exception:
               error_str = traceback.format_exc()
               logger.error("This prints the stack", exc_info=True)
               return UserServiceError.to_response(error=error_str, comments="Something went wrong while logging in") 
    

    最佳答案

    问题是 known issue在flask-sqlalchemy 中,由SQLAchemy 1.4 中的更改引起。 Flask-sqlalchemy 尝试修改 SQLALchemy 引擎的 URL,但这些 URL 在 SQLAlchemy 1.4 中是不可变的。
    该问题已在 Flask-SQLAlchemy 2.5+ ( changelog ) 中修复。
    如果无法升级 Flask-SQLAlchemy,可以通过指定传递给 pip 的 SQLAlchemy 版本来解决该问题。 , 或者通过命令行

    pip install --upgrade 'SQLAlchemy<1.4'
    
    或在requirements.txt
    SQLAlchemy<1.4
    
    SQLAlchemy 1.4 于 2021 年 3 月 15 日正式发布。

    关于python - 从 RDS 检索数据给出 AttributeError : 'sqlalchemy.cimmutabledict.immutabledict' object has no attribute 'setdefault' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65610809/

    相关文章:

    python - 不可 JSON 序列化的项目的管道

    mysql - 在没有 DATE 字段的 SQL 中选择日期范围

    mysql - 使用 SQL 或 PHP 选择值

    python - 如何刷新 flask 网页?

    python - Keras LSTM 不同的输入输出形状

    python - 如何在此代码中制作对角线?

    mysql - 子查询返回多行错误

    python - Flask - 无法访问根地址的静态文件

    flask - 如何在 Flask 页面请求之间保留查询?

    python - 将嵌套字典写入 csv