3 个版本
0.1.2 | 2023年12月13日 |
---|---|
0.1.1 | 2023年6月9日 |
0.1.0 | 2023年6月6日 |
在 数据库接口 中排名第 1619
每月下载量 26 次
1.5MB
729 行代码
Promad
ProMad 是一个 SQLx 迁移工具,允许在写入连接的事务中执行任意的 SQL/Rust 代码。
特性
- 在迁移中混合 Rust 代码和 SQL。
- 使用 Rust 扫描包含 blob 数据的表迁移。
- 可嵌入的 CLI。
示例
# #[tokio::main]
# async fn main() {
use std::borrow::Cow;
use async_trait::async_trait;
use promad::{file_basename, Migration, Migrator, error::{Error, Result}};
use sqlx::{postgres::PgPoolOptions, PgPool, Postgres, Executor, Row};
use testcontainers::{clients, Container};
pub struct FirstMigration;
#[async_trait]
impl Migration<Postgres> for FirstMigration {
fn name(&self) -> &'static str {
file_basename!()
}
async fn up(
&self,
_read: &mut sqlx::PgConnection,
write: &mut sqlx::PgConnection,
) -> Result<()> {
sqlx::query("CREATE TABLE test (id INT PRIMARY KEY)")
.execute(write)
.await?;
Ok(())
}
async fn down(
&self,
_read: &mut sqlx::PgConnection,
write: &mut sqlx::PgConnection,
) -> Result<()> {
sqlx::query("DROP TABLE test")
.execute(write)
.await?;
Ok(())
}
}
let docker = clients::Cli::default();
let pgsql = docker.run(testcontainers::images::postgres::Postgres::default());
let port = pgsql.get_host_port_ipv4(5432);
let pool = PgPoolOptions::new()
.connect(&format!(
"postgres://postgres:postgres@localhost:{}/postgres",
port
))
.await.unwrap();
let mut migrator = Migrator::create(pool.clone());
migrator.add_migration(Box::new(FirstMigration));
migrator.apply_all().await.unwrap();
// Check that the table exists.
let mut conn = pool.acquire().await.unwrap();
let row = sqlx::query("SELECT EXISTS (SELECT FROM information_schema.tables WHERE table_schema = 'public' AND table_name = 'test')")
.fetch_one(conn.as_mut())
.await.unwrap();
assert!(row.get::<bool, _>(0));
migrator.revert_all().await.unwrap();
let row = sqlx::query("SELECT EXISTS (SELECT FROM information_schema.tables WHERE table_schema = 'public' AND table_name = 'test')")
.fetch_one(conn.as_mut())
.await.unwrap();
assert!(!row.get::<bool, _>(0));
# }
依赖项
~39–52MB
~872K SLoC