원클릭으로
sqlx-postgres
SQLx + PostgreSQL v17 database guide. Queries, migrations, ENUMs, JSONB, transactions.
Codex 또는 Claude로 설치 이 Prompt를 복사해 Codex, Claude 또는 다른 어시스턴트에 붙여 넣으면 Skill 페이지를 검토하고 설치를 진행할 수 있습니다.
메뉴
SQLx + PostgreSQL v17 database guide. Queries, migrations, ENUMs, JSONB, transactions.
Codex 또는 Claude로 설치 이 Prompt를 복사해 Codex, Claude 또는 다른 어시스턴트에 붙여 넣으면 Skill 페이지를 검토하고 설치를 진행할 수 있습니다.
Claude + Gemini + Codex 4者クロスファクトチェック。Opus自身、Gemini Flash、Gemini Pro、Codex (gpt-5.3-codex) の4者で独立チェック→争点抽出→議論→合意レポートを出力する。
Claude + Gemini クロスファクトチェック。Opus自身、Gemini Flash、Gemini Proの3者で独立チェック→争点抽出→議論→合意レポートを出力する。
Claude内マルチモデルファクトチェック。Opusが自身でチェックし、Sonnetサブエージェントに独立チェックさせ、両者の結果を比較・議論して合意レポートを出力する。
Gemini CLIのGoogle検索統合(grounding)を使ったWeb検索。Claudeは結果の整形・要約のみ担当し、WebSearchツールは使用しない。
Axum v0.8.x backend development guide. Handlers, routing, middleware, auth, error handling.
Dioxus v0.7.x desktop app guide. Components, Signal state, rsx! macro, hooks, events, Context API, async.
SOC 직업 분류 기준
| name | sqlx-postgres |
| description | SQLx + PostgreSQL v17 database guide. Queries, migrations, ENUMs, JSONB, transactions. |
// query_as! (type-safe)
let user = sqlx::query_as!(
User,
r#"SELECT id, name, email, role as "role: UserRole" FROM users WHERE id = $1"#,
id
).fetch_one(&pool).await?;
// Single column
let count = sqlx::query_scalar!("SELECT COUNT(*) FROM users WHERE active = true")
.fetch_one(&pool).await?;
// INSERT/UPDATE/DELETE
sqlx::query!("INSERT INTO users (name, email) VALUES ($1, $2)", name, email)
.execute(&pool).await?;
.fetch_one(&pool) // 1 row (error if 0 or 2+)
.fetch_optional(&pool) // 0-1 row (Option<T>)
.fetch_all(&pool) // All rows (Vec<T>)
.fetch(&pool) // Stream (Stream<T>)
.execute(&pool) // Execute only (PgQueryResult)
-- Migration
CREATE TYPE user_role AS ENUM ('Admin', 'AreaManager', 'ServiceStation');
#[derive(Debug, Clone, sqlx::Type, Serialize, Deserialize)]
#[sqlx(type_name = "user_role", rename_all = "PascalCase")]
pub enum UserRole { Admin, AreaManager, ServiceStation }
// Query (cast required)
sqlx::query_as!(User, r#"SELECT role as "role: UserRole" FROM users"#)
#[derive(Debug, Serialize, Deserialize)]
pub struct Metadata { pub tags: Vec<String> }
// INSERT
sqlx::query!("INSERT INTO items (metadata) VALUES ($1)", sqlx::types::Json(metadata) as _)
.execute(&pool).await?;
// SELECT
sqlx::query_as!(Item, r#"SELECT metadata as "metadata: Json<Metadata>" FROM items"#)
let mut tx = pool.begin().await?;
sqlx::query!("INSERT INTO users (name) VALUES ($1)", name)
.execute(&mut *tx).await?;
sqlx::query!("INSERT INTO profiles (user_id) VALUES ($1)", user_id)
.execute(&mut *tx).await?;
tx.commit().await?;
// Error → tx drops → auto rollback
#[derive(Deserialize)]
pub struct Pagination { page: Option<i64>, per_page: Option<i64> }
impl Pagination {
pub fn offset(&self) -> i64 { (self.page.unwrap_or(1) - 1) * self.per_page() }
pub fn per_page(&self) -> i64 { self.per_page.unwrap_or(20).min(100) }
}
sqlx::query_as!(User, "SELECT * FROM users LIMIT $1 OFFSET $2",
pagination.per_page(), pagination.offset())
let names: Vec<String> = items.iter().map(|i| i.name.clone()).collect();
let values: Vec<i32> = items.iter().map(|i| i.value).collect();
sqlx::query!(
"INSERT INTO items (name, value) SELECT * FROM UNNEST($1::text[], $2::int[])",
&names, &values
).execute(&pool).await?;
sqlx::query!(
r#"INSERT INTO prices (station_id, fuel_type, price)
VALUES ($1, $2, $3)
ON CONFLICT (station_id, fuel_type)
DO UPDATE SET price = EXCLUDED.price, recorded_at = NOW()"#,
station_id, fuel_type as _, price
).execute(&pool).await?;
let mut builder = QueryBuilder::new("SELECT * FROM users WHERE 1=1");
if let Some(name) = &filter.name {
builder.push(" AND name ILIKE ").push_bind(format!("%{}%", name));
}
builder.push(" ORDER BY id LIMIT ").push_bind(limit);
builder.build_query_as::<User>().fetch_all(&pool).await?
sqlx migrate add create_users_table
sqlx migrate run
sqlx migrate revert
role as "role: UserRole" format requiredOption<T> for nullable columnsDATABASE_URL envcargo sqlx prepare generates .sqlx dir&pool for normal, &mut *tx for transactions