使用 SeaORM 删除数据

252313
2022/06/01 01:51:42

物理删除

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

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

逻辑删除

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/删除数据分支。