AttributeError:“dict”对象没有属性“_sa_instance_state”

Ruk*_*ama 5 sqlalchemy python-3.x flask-restful marshmallow

正在使用和创建一个flask_restfulAPI 。这是我的模型sqlalchemymarshmallow

class User(db.Model):
    """Basic user model
    """

    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(80), unique=True, nullable=False)
    email = db.Column(db.String(80), unique=True, nullable=False)
    password = db.Column(db.String(255), nullable=False)
    active = db.Column(db.Boolean, default=True)
    is_admin = db.Column(db.Boolean, default=False)
    profile = db.relationship("Profile", back_populates="user", uselist=False)

class Profile(db.Model):
    """Profile model
    """

    id = db.Column(db.Integer, primary_key=True)
    fullname = db.Column(db.String(80), unique=False, nullable=True)
    img_url = db.Column(db.String(255), unique=False, nullable=True)
    telephone = db.Column(db.String(20), unique=False, nullable=True)
    user_id = db.Column(
        db.Integer,
        db.ForeignKey('user.id'),
        nullable=False)
    user = db.relationship("User", back_populates="profile")
Run Code Online (Sandbox Code Playgroud)

这里是用于更新PUT请求的用户资源

class UserResource(Resource):

    def put(self, user_id):
        schema = UserSchema()
        user = User.query.get_or_404(user_id)

        data = {
            'username': 'updated',
            "password": 'HRcdxRu45',
            'email': 'ms@gt.vom',
            'profile': {
                'telephone': '+2507800112233',
                'fullname': 'Mic Lolo',
                'img_url': 'images/img.jpg'
            }
        }

        user = schema.load(data, instance=user)

        return {"message": "user updated", "data": schema.dump(user)}

Run Code Online (Sandbox Code Playgroud)

这是我的架构

class ProfileSchema(ma.Schema):
    id = ma.Int(dump_only=True)
    fullname = ma.Str(validate=Length(min=3, max=80, error='empty fullname'))
    img_url = ma.Str(validate=Length(min=3, max=80, error='empty image url'))
    telephone = ma.Str(validate=Regexp(regex=r"\+[0-9]{7,13}", error="Invalid phone number"))

    class Meta:
        model = Profile
        sqla_session = db.session


class UserSchema(ma.ModelSchema):
    id = ma.Int(dump_only=True)
    password = ma.Str(load_only=True,
                      validate=Length(min=8, max=255, error='empty password'))
    username = ma.Str(validate=Length(min=3, max=80, error='empty username'))
    is_admin = ma.Bool()
    email = ma.Email()
    profile = ma.Nested(ProfileSchema)

    class Meta:
        model = User
        sqla_session = db.session

Run Code Online (Sandbox Code Playgroud)

我收到 AttributeError: 'dict' 对象没有属性 '_sa_instance_state'

当我从中删除嵌套配置文件架构时,UserSchema没有错误,但user.profile不会更新。此外,当我删除instance=user参数时,schema.load(data, instance=user)没有错误,并且我将获得一个带有已发布数据的良好用户实例,这里的问题又是该用户实例与数据库中现有的实例之间不会有任何链接,我将不得不手动查找要更新的用户字段。

And*_*rew 3

class ProfileSchema(ma.Schema):
Run Code Online (Sandbox Code Playgroud)

ProfileSchema应该继承自ma.ModelSchema

  • 为什么这有效? (2认同)