Install
Terminal · npx$
npx skills add https://github.com/affaan-m/everything-claude-code --skill postgres-patternsWorks with Paperclip
How Postgres Patterns fits into a Paperclip company.
Postgres Patterns drops into any Paperclip agent that handles this kind of work. Assign it to a specialist inside a pre-configured PaperclipOrg company and the skill becomes available on every heartbeat — no prompt engineering, no tool wiring.
S
SaaS FactoryPaired
Pre-configured AI company — 18 agents, 18 skills, one-time purchase.
$27$59
Explore packSource file
SKILL.md147 linesExpandCollapse
---name: postgres-patternsdescription: PostgreSQL database patterns for query optimization, schema design, indexing, and security. Based on Supabase best practices.origin: ECC--- # PostgreSQL Patterns Quick reference for PostgreSQL best practices. For detailed guidance, use the `database-reviewer` agent. ## When to Activate - Writing SQL queries or migrations- Designing database schemas- Troubleshooting slow queries- Implementing Row Level Security- Setting up connection pooling ## Quick Reference ### Index Cheat Sheet | Query Pattern | Index Type | Example ||--------------|------------|---------|| `WHERE col = value` | B-tree (default) | `CREATE INDEX idx ON t (col)` || `WHERE col > value` | B-tree | `CREATE INDEX idx ON t (col)` || `WHERE a = x AND b > y` | Composite | `CREATE INDEX idx ON t (a, b)` || `WHERE jsonb @> '{}'` | GIN | `CREATE INDEX idx ON t USING gin (col)` || `WHERE tsv @@ query` | GIN | `CREATE INDEX idx ON t USING gin (col)` || Time-series ranges | BRIN | `CREATE INDEX idx ON t USING brin (col)` | ### Data Type Quick Reference | Use Case | Correct Type | Avoid ||----------|-------------|-------|| IDs | `bigint` | `int`, random UUID || Strings | `text` | `varchar(255)` || Timestamps | `timestamptz` | `timestamp` || Money | `numeric(10,2)` | `float` || Flags | `boolean` | `varchar`, `int` | ### Common Patterns **Composite Index Order:**```sql-- Equality columns first, then range columnsCREATE INDEX idx ON orders (status, created_at);-- Works for: WHERE status = 'pending' AND created_at > '2024-01-01'``` **Covering Index:**```sqlCREATE INDEX idx ON users (email) INCLUDE (name, created_at);-- Avoids table lookup for SELECT email, name, created_at``` **Partial Index:**```sqlCREATE INDEX idx ON users (email) WHERE deleted_at IS NULL;-- Smaller index, only includes active users``` **RLS Policy (Optimized):**```sqlCREATE POLICY policy ON orders USING ((SELECT auth.uid()) = user_id); -- Wrap in SELECT!``` **UPSERT:**```sqlINSERT INTO settings (user_id, key, value)VALUES (123, 'theme', 'dark')ON CONFLICT (user_id, key)DO UPDATE SET value = EXCLUDED.value;``` **Cursor Pagination:**```sqlSELECT * FROM products WHERE id > $last_id ORDER BY id LIMIT 20;-- O(1) vs OFFSET which is O(n)``` **Queue Processing:**```sqlUPDATE jobs SET status = 'processing'WHERE id = ( SELECT id FROM jobs WHERE status = 'pending' ORDER BY created_at LIMIT 1 FOR UPDATE SKIP LOCKED) RETURNING *;``` ### Anti-Pattern Detection ```sql-- Find unindexed foreign keysSELECT conrelid::regclass, a.attnameFROM pg_constraint cJOIN pg_attribute a ON a.attrelid = c.conrelid AND a.attnum = ANY(c.conkey)WHERE c.contype = 'f' AND NOT EXISTS ( SELECT 1 FROM pg_index i WHERE i.indrelid = c.conrelid AND a.attnum = ANY(i.indkey) ); -- Find slow queriesSELECT query, mean_exec_time, callsFROM pg_stat_statementsWHERE mean_exec_time > 100ORDER BY mean_exec_time DESC; -- Check table bloatSELECT relname, n_dead_tup, last_vacuumFROM pg_stat_user_tablesWHERE n_dead_tup > 1000ORDER BY n_dead_tup DESC;``` ### Configuration Template ```sql-- Connection limits (adjust for RAM)ALTER SYSTEM SET max_connections = 100;ALTER SYSTEM SET work_mem = '8MB'; -- TimeoutsALTER SYSTEM SET idle_in_transaction_session_timeout = '30s';ALTER SYSTEM SET statement_timeout = '30s'; -- MonitoringCREATE EXTENSION IF NOT EXISTS pg_stat_statements; -- Security defaultsREVOKE ALL ON SCHEMA public FROM public; SELECT pg_reload_conf();``` ## Related - Agent: `database-reviewer` - Full database review workflow- Skill: `clickhouse-io` - ClickHouse analytics patterns- Skill: `backend-patterns` - API and backend patterns --- *Based on Supabase Agent Skills (credit: Supabase team) (MIT License)*Related skills
Agent Eval
Install Agent Eval skill for Claude Code from affaan-m/everything-claude-code.
Agent Harness Construction
Install Agent Harness Construction skill for Claude Code from affaan-m/everything-claude-code.
Agent Payment X402
Install Agent Payment X402 skill for Claude Code from affaan-m/everything-claude-code.