Seeding Data
You can retrieve a DbConn
from SchemaManager
and perform data operations as needed, for example, to seed data.
use sea_orm_migration::sea_orm::{entity::*, query::*};
// ...
#[async_trait]
impl MigrationTrait for Migration {
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
let db = manager.get_connection();
cake::ActiveModel {
name: Set("Cheesecake".to_owned()),
..Default::default()
}
.insert(db)
.await?;
Ok(())
}
}
You could also write SeaQuery statement to seed the table.
use sea_orm_migration::sea_orm::{entity::*, query::*};
// ...
#[async_trait]
impl MigrationTrait for Migration {
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
let insert = Query::insert()
.into_table(Cake::Table)
.columns([Cake::Name])
.values_panic(["Tiramisu".into()])
.to_owned();
manager.exec_stmt(insert).await?;
Ok(())
}
}
/// Learn more at https://docs.rs/sea-query#iden
#[derive(Iden)]
pub enum Cake {
Table,
Id,
Name,
}
Seeding Data Transactionally
Starts a transaction and execute SQL inside migration up and down.
use sea_orm_migration::sea_orm::{entity::*, query::*};
// ...
#[async_trait]
impl MigrationTrait for Migration {
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
// Get the connection and start a transaction
let db = manager.get_connection();
let transaction = db.begin().await?;
// Insert with the transaction connection
cake::ActiveModel {
name: Set("Cheesecake".to_owned()),
..Default::default()
}
.insert(&transaction)
.await?;
// Commit it
transaction.commit().await?;
Ok(())
}
}