使用 SeaORM 修改数据

代码

pub async fn edit(
    Extension(state): Extension<Arc<AppState>>,
    Form(frm): Form<form::CategoryForm>,
    Path(id): Path<i32>,
) -> Result<RedirectRespon> {
    let handler_name = "category/edit";
    let conn = get_conn(&state);
    let am = category::ActiveModel {
        id: Unchanged(id),
        name: Set(frm.name),
        ..Default::default()
    };
    am.update(conn)
        .await
        .map_err(AppError::from)
        .map_err(log_error(handler_name))?;
    redirect("/category?msg=分类修改成功")
}

Unchanged()

Unchanged() 用于指定不参与数据库的SET。因为我们的id只是为了标识某条记录,以便于更新该条记录的其它字段,所以id本身是不需要修改的。

update()

update() 执行数据库的 UPDATE 操作。

自动决定是更新还是插入 - save()

上一章我们使用 insert()来插入数据,本章我们使用update()来更新数据。其实 SeaORM 提供了 save(),它可以自动决定是插入还是更新:

// INSERT
category::ActiveModel {
        id: NotSet,
        name: Set(name),
        ..Default::default()
    }.save(conn).await.unwarp();

// UPDATE
category::ActiveModel {
        id: Unchanged(id),
        name: Set(name),
        ..Default::default()
    }.save(conn).await.unwarp();

// UPDATE
category::ActiveModel {
        id: Set(id),
        name: Set(name),
        ..Default::default()
    }.save(conn).await.unwarp();

ActiveValue枚举

本章代码位于04/修改数据分支

要查看完整内容,请先登录