@router.put("/role/{role_id}", summary="修改角色权限")
async def setRole(*,
db: Session = Depends(deps.get_db),
u: Users = Depends(deps.user_perm(["perm:role:put"])),
role_id: int,
obj: RoleSchema
):
curd_role.update(db, _id=role_id, obj_in=obj, modifier_id=u['id'])
return respSuccessJson()
def update(self, db: Session, *, _id: int, obj_in: Union[UpdateSchemaType, Dict[str, Any]],
modifier_id: int = 0) -> ModelType:
""" 更新 """
update_data = jsonable_encoder(obj_in, custom_encoder={dict: custom_encoder_dict_fn})
update_data['modifier_id'] = modifier_id
update_data = {getattr(self.model, k): v for k, v in update_data.items() if hasattr(self.model, k)}
obj = db.query(self.model).filter(self.model.id ==_id, self.model.is_deleted != 1).update(update_data)
db.commit()
return obj
这是一个Python中用于更新数据库记录的方法。它接受数据库会话(db)、记录的ID(_id)、更新数据(obj_in)以及修改者的ID(modifier_id)作为参数。在方法内部,首先将更新数据转换为可JSON序列化的格式,然后将修改者的ID添加到更新数据中。接着,它将更新数据中的字段映射到数据库模型中的字段,并使用query方法来过滤出符合条件的记录,然后对其进行更新。最后,提交数据库会话并返回更新后的对象。
这个方法的作用是根据给定的ID和更新数据来更新数据库中的记录,并返回更新后的对象。