域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。现在,我们已启用新域名 AXUM.EU.ORG
  • 方案AXUM.RS 域名 = 3000
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名,或者该域名到期,本站将使用免费域名 AXUM.EU.ORG 继续提供服务。

使用 SeaORM 删除数据

物理删除

逻辑删除

所谓逻辑删除,是指通过修改is_del的值为TRUE来实现,其实就是一个UPDATE操作。下面是使用save()的示例。

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

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

代码

src/handler/category.rs

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=分类删除成功")
}
要查看完整内容,请先登录