使用 SeaORM 插入数据

本章将讨论如何使用 SeaORM 添加记录。

category-insert

ActiveModel

之前的章节讨论过,Model是只读的,只能用来SELECT;而 INSERT/UPDATE/DELETE 等属于写操作,需使用 ActiveModel

代码

src/handler/category.rs

pub async fn add(
    Extension(state): Extension<Arc<AppState>>,
    Form(frm): Form<form::CategoryForm>,
) -> Result<RedirectRespon> {
    let handler_name = "category/add";
    let conn = get_conn(&state);
    let am = category::ActiveModel {
        name: Set(frm.name),
        ..Default::default()
    };
    let added_category: category::Model = am
        .insert(conn)
        .await
        .map_err(AppError::from)
        .map_err(log_error(handler_name))?;
    let url = format!("/category?msg=分类添加成功,ID是:{}", added_category.id);
    redirect(url.as_str())
}
  • Form(frm): Form<form::CategoryForm>:获取表单输入,该文件位于src/form.rs
  • let am = category::ActiveModel { ... }; :使用表单输入的值构造一个 ActiveModel,其中的 Set()见下文
  • let added_category: category::Model = am.insert(conn)...;:调用 ActiveModelinsert()方法,将数据写入到数据库中

⚠️ 提示:千万别忘了 Set

async insert():执行数据库的INSERT操作。

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