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

使用 SeaORM 删除数据

本章将讨论如何使用 SeaORM 实现删除。

所谓物理删除,是指定执行 SQL 的 DELETE 语句,将记录从数据库中删除。在 SeaORM 中,使用 delete_by_id()可以实现通过主键来删除:

category::Entity::delete_by_id(id)
            .exec(conn)
            .await
						.unwarp();

逻辑删除

再次提醒,只有自增主键才能使用save()

category::ActiveModel {
            id: Unchanged(id),
            is_del: Set(true),
            ..Default::default()
        }
        .save(conn)
        .await
				.unwrap();

src/handler/category.rs

pub async fn del(
    Extension(state): Extension<Arc<AppState>>,
    Path(params): Path<param::DelParams>,
) -> Result<RedirectRespon> {
    let handler_name = "category/del";
    let conn = get_conn(&state);
    let real = params.real.unwrap_or(false);
    let id = params.id;
    if real {
        category::Entity::delete_by_id(id)
            .exec(conn)
            .await
            .map_err(AppError::from)
            .map_err(log_error(handler_name))?;
    } else {
        category::ActiveModel {
            id: Unchanged(id),
            is_del: Set(true),
            ..Default::default()
        }
        .save(conn)
        .await
        .map_err(AppError::from)
        .map_err(log_error(handler_name))?;
    }
    redirect("/category?msg=分类删除成功")
}

本章代码位于05/删除数据分支。

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