PUT 请求不起作用,Flask-RESTful,SQLAlchemy

Ala*_*n J 4 sqlalchemy put flask flask-sqlalchemy flask-restful

我相信问题在于提交对数据库的更改(倒数第三行:)db.session.commit()。以一个用户为例:username="Foo", email="Bar@yahoo.com"。如果在 PUT 请求正文中我放了 {"email":"changed@gmail.com"},则在赋值后打印 'user.email' 表明该值实际上已更改。然而之后,在查询数据库时,电子邮件保持不变。无论如何,我真的很难弄清楚我错过了什么,所以感谢任何帮助!

class UserAPI(Resource):
    def __init__(self):
        self.parser = reqparse.RequestParser()
        self.parser.add_argument('username', type=str, location='json')
        self.parser.add_argument('email', type=str, location='json')
        self.parser.add_argument('password', type=str, location='json')
        super(UserAPI, self).__init__()

    def put(self, id): 
        # Not working
        user = User.query.filter_by(id=id).first()
        if user is not None:
            args = self.parser.parse_args()
            for key, value in args.items():
                if args[key] is not None:
                    user.key = value
            db.session.commit()
            return {"user": marshal(user,user_field) }
        return {"error": "User not found"}, 404
Run Code Online (Sandbox Code Playgroud)

小智 5

更改user.key = valuesetattr(user, key, value)

而不是在这里设置您想要的属性 ( user.email) 您正在设置user.key。因为user.key可能不是数据库列字段(当然也不是您打算设置的字段),所以在db.session.commit()调用时更改不会序列化到数据库中。