schema-architect
SKILL.md
Schema Architect Protocol
This skill transforms raw business requirements into a robust, normalized, and scalable database schema. It avoids common anti-patterns like "God Tables" or EAV (Entity-Attribute-Value) abuse.
Core assumption: A good schema must be extensible, maintainable, and explicitly document your design choices.
1. Requirement Analysis & Normalization Phase
Before writing any SQL, analyze the request:
- Identify Entities & Relationships: What are the root domains? (e.g. Users, Orders, Products). What are the cardinalities?
- Normalization Strategy (1NF → 3NF → BCNF):
- Ensure data is logically divided.
- Stop at 3NF for most OLTP systems. Denormalize ONLY if there is a documented performance optimization justification.
2. Anti-Pattern Check
Scan your intended design against common pitfalls:
- ❌ God Table: Does one table have >30 columns handling multiple disconnected responsibilities (e.g.,
Usershaving billing, shipping, and auth info in one huge table)? → Split them! - ❌ EAV (Entity-Attribute-Value) Abuse: Are you using EAV patterns instead of JSONB or proper typed tables? → Rework to standard models where possible!
- ❌ Polymorphic Associations: Using
entity_idandentity_typewithout Foreign Key constraints? → Use standard associative tables or exclusive arcs!
3. Dialect Selection & Output Generation
Identify the target database (agnostic approach). Generate platform-specific SQL schema.
Required Outputs (Must write BOTH to docs/database-report/):
- Human-Readable Markdown (
docs/database-report/schema-architect-report.md)
### 🏗️ Schema Generation Report
- **Target Dialect:** [PostgreSQL/MySQL/Snowflake]
- **Normalization Level:** [e.g., 3NF]
- **Trade-offs made:** [Fast Read vs. Fast Write considerations]
#### 📜 Generated DDL
```sql
CREATE TABLE users (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
email VARCHAR(255) UNIQUE NOT NULL,
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
);
2. **Machine-Readable JSON (`docs/database-report/schema-architect-output.json`)**
```json
{
"skill": "schema-architect",
"dialect": "PostgreSQL",
"entities": ["users"],
"relations": [],
"raw_ddl": "CREATE TABLE..."
}
4. Execution Context
- Default (Static): Analyze based on provided requirements or existing schema files (e.g.,
schema.prismaor.sqlfiles). - Dynamic (On-Demand): Only connect to a live database to introspect the current schema if the user explicitly requests it.
Guardrails
- No Vague Types: Do not use
VARCHARwithout limits unless using PostgreSQLTEXT. Use proper types (JSONB,NUMERIC(p,s),TIMESTAMPTZvsTIMESTAMP). - Primary Keys: Default to
UUIDv7orBIGSERIAL/BIGINT IDENTITYfor primary keys for distributed readiness. - Audit Columns:
created_atandupdated_atmust exist on almost all operational operational tables.
🔗 Next Steps & Handoffs
If you are executing the New Schema Design Flow as defined in the Database ECOSYSTEM guide, and the schema has been successfully generated, the next mandatory skill in the sequence is:
@access-policy-designer(to design Row-Level Security constraints or app-level access controls for the new tables)
Weekly Installs
1
Repository
fatih-developer…h-skillsGitHub Stars
1
First Seen
13 days ago
Security Audits
Installed on
amp1
cline1
opencode1
cursor1
kimi-cli1
codex1