Our review
This skill helps write SQL queries, optimize performance, design schemas, and debug database issues.
Strengths
- Provides concrete examples of basic and advanced queries
- Includes optimization techniques (indexes, EXPLAIN)
- Offers common patterns like pagination and upsert
Limitations
- Does not replace a DBA for complex configurations
- Optimizations may vary depending on the DBMS
Use this skill when working with SQL databases, optimizing queries, or designing schemas.
Do not use it for non-relational (NoSQL) tasks or if you need advanced system administration.
Security analysis
SafeThe skill provides SQL syntax examples and best practices, with no instructions to execute harmful commands or access sensitive data. The Bash tool is permitted but not utilized in the skill's content, so it poses no direct risk.
No concerns found
Examples
/sql I have a query that runs slowly: SELECT * FROM orders WHERE user_id = 123 ORDER BY created_at DESC; Please suggest indexes and use EXPLAIN to optimize it./sql Design a schema for a blog with users, posts, and comments. Include foreign keys, indexes, and a migration to add a 'published' column to posts.name: sql description: Write SQL queries, optimize database performance, design schemas, and debug SQL issues. Use for database operations, query optimization, and schema design. allowed-tools: Read, Bash
SQL Skill
Comprehensive SQL assistance for database operations.
1. Query Writing
Basic Queries:
-- SELECT with WHERE
SELECT name, email FROM users WHERE active = true;
-- JOIN operations
SELECT u.name, o.total
FROM users u
INNER JOIN orders o ON u.id = o.user_id;
-- Aggregate functions
SELECT category, COUNT(*), AVG(price)
FROM products
GROUP BY category
HAVING COUNT(*) > 5;
-- Subqueries
SELECT * FROM users
WHERE id IN (SELECT user_id FROM orders WHERE total > 1000);
2. Query Optimization
Use EXPLAIN:
EXPLAIN ANALYZE
SELECT * FROM users WHERE email = 'test@example.com';
-- Look for:
-- - Sequential scans (add indexes)
-- - High cost values
-- - Nested loops on large tables
Add Indexes:
-- Single column index
CREATE INDEX idx_users_email ON users(email);
-- Multi-column index
CREATE INDEX idx_orders_user_date ON orders(user_id, created_at);
-- Unique index
CREATE UNIQUE INDEX idx_users_username ON users(username);
-- Partial index
CREATE INDEX idx_active_users ON users(email) WHERE active = true;
3. Schema Design
Tables:
CREATE TABLE users (
id SERIAL PRIMARY KEY,
email VARCHAR(255) UNIQUE NOT NULL,
name VARCHAR(100) NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE orders (
id SERIAL PRIMARY KEY,
user_id INTEGER REFERENCES users(id) ON DELETE CASCADE,
total DECIMAL(10,2) NOT NULL,
status VARCHAR(50) DEFAULT 'pending',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
4. Migrations
Add Column:
ALTER TABLE users ADD COLUMN phone VARCHAR(20);
-- Add with default
ALTER TABLE users ADD COLUMN verified BOOLEAN DEFAULT false;
Modify Column:
ALTER TABLE users ALTER COLUMN email TYPE VARCHAR(320);
ALTER TABLE users ALTER COLUMN name SET NOT NULL;
5. Transactions
BEGIN;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;
-- With error handling
BEGIN;
-- operations
SAVEPOINT sp1;
-- more operations
ROLLBACK TO sp1;
COMMIT;
6. Common Patterns
Pagination:
SELECT * FROM products
ORDER BY created_at DESC
LIMIT 20 OFFSET 40;
Upsert:
INSERT INTO users (email, name)
VALUES ('test@example.com', 'Test')
ON CONFLICT (email)
DO UPDATE SET name = EXCLUDED.name;
Window Functions:
SELECT
name,
salary,
RANK() OVER (ORDER BY salary DESC) as rank
FROM employees;
When to Use This Skill
Use /sql when working with databases, optimizing queries, or designing schemas.
Prompt Engineering
Data & AI
Prompt engineering best practices and templates to maximize AI outputs.
Data Visualization
Data & AI
Generates data visualizations and charts tailored to your data.
RAG Architecture Setup
Data & AI
Setup guide for RAG (Retrieval-Augmented Generation) architectures.