name: MongoDB Best Practices description: Expert rules for schema design, indexing, and performance in MongoDB (NoSQL). metadata: labels: [mongodb, nosql, mongoose, database, performance] triggers: files: ['/*.ts', '/.js', '**/.json'] keywords: [mongo, mongoose, objectid, schema, model]
MongoDB Best Practices
Priority: P0 (CRITICAL)
Guidelines
Schema Design:
- Embed vs Reference:
- Embed (1:Few): Addresses, Phone Numbers. Optimization: Read locality.
- Reference (1:Many/Infinity): Logs, Activity History. Optimization: Document size limits (16MB).
- Bucket Pattern: For time-series or high-cardinality "One-to-Many", bucket items into documents (e.g.,
DailyLog).
- Embed vs Reference:
Indexing:
- ESR Rule: Equality, Sort, Range. Order your index keys
(status, date, price)if you querystatus='A', sort bydate, filterprice > 10. - Text Search: Use
$textsearch instead of$regexfor keywords.$regexis slow (linear scan) unless anchored (^prefix). - Covered Queries: Project only indexed fields to avoid fetching the document (
PROJECTIONis key). - Explain Plan: Target
nReturned/keysExaminedratio of ~1. IfdocsExamined>>nReturned, index is inefficient.
- ESR Rule: Equality, Sort, Range. Order your index keys
Sharding (Horizontal Scale):
- Shard Key: Avoid monotonically increasing keys (e.g.,
Timestamp,ObjectId) for high-write workloads (creates "Hot Shards"). Use Hashed Sharding or high-cardinality natural keys.
- Shard Key: Avoid monotonically increasing keys (e.g.,
Performance:
- Avoid
skip(): Use_idor sort-key based pagination (bucket_id > last_id).skip(10000)scans 10000 docs. - Aggregation: Prefer Aggregation Framework (
$match,$group) over bringing data to client (JS).
- Avoid
Operations:
- Write Concern: Understand
w:1(Ack) vsw:majority(Safe). - Transactions: Use only when ACID across multiple documents is stricter than performance needs.
- Write Concern: Understand
Anti-Patterns
- Large Arrays: Don't let arrays grow unboundedly (
$pushwithout limit). - Client-Side Filtering: Don't fetch 1MB document to use 1KB of data.
- Deep Nesting: Avoid >4 levels of nesting (hard to query/update).