域名 AXUM.RS 将于 2025 年 10 月到期。我们无意再对其进行续费,如果你有意接续这个域名,请与我们取得联系。
  • AXUM.RS 现仅需人民币 3000 元(大写:叁仟元整。接受适度议价
  • 按照行业规则,AXUM.RS 到期后,大概率会进入长时间的赎回期,该期间内,如果你想拥有该域名,将要付出高额的费用
  • 我们已启用 AXUM.EU.ORG 域名,并将持续运营
  • 仅接受微信或支付宝交易
如果你对 AXUM.RS 有兴趣,请和我们进行联系:

使用 SeaORM 修改数据

代码

src/handler/category.rs

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 操作。

  • 当主键为 NotSet 时,执行 INSERT
  • 当主键为 SetUnChange时,执行 UPDATE
// 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();

⚠️ save() 仅适用于自增长的主键

ActiveValue枚举

SetNotSetUnchanged 都是 ActiveValue的枚举值。

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

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