From mongodb-skills
Provides MongoDB schema design patterns and anti-patterns for data modeling, schema reviews, SQL migrations, and performance troubleshooting from schema issues.
npx claudepluginhub fcakyon/claude-codex-settings --plugin mongodb-skillsThis skill uses the workspace's default tool permissions.
Data modeling patterns and anti-patterns for MongoDB, maintained by MongoDB. Bad schema is the root cause of most MongoDB performance and cost issues—queries and indexes cannot fix a fundamentally wrong model.
references/antipattern-excessive-lookups.mdreferences/antipattern-unnecessary-collections.mdreferences/antipattern-unnecessary-indexes.mdreferences/fundamental-document-model.mdreferences/fundamental-document-size.mdreferences/fundamental-embed-vs-reference.mdreferences/fundamental-schema-validation.mdreferences/pattern-approximation.mdreferences/pattern-archive.mdreferences/pattern-attribute.mdreferences/pattern-bucket.mdreferences/pattern-computed.mdreferences/pattern-document-versioning.mdreferences/pattern-extended-reference.mdreferences/pattern-outlier.mdreferences/pattern-polymorphic.mdreferences/pattern-schema-versioning.mdreferences/pattern-time-series-collections.mdProvides MongoDB schema design patterns and anti-patterns for data modeling, schema reviews, SQL migrations, and performance troubleshooting from schema issues.
Provides MongoDB schema design patterns and anti-patterns for data modeling, schema reviews, SQL migrations, and troubleshooting performance issues from bad schemas.
Designs NoSQL schemas for MongoDB and DynamoDB including document modeling, collection/table design, indexing, denormalization, and query optimization.
Share bugs, ideas, or general feedback.
Data modeling patterns and anti-patterns for MongoDB, maintained by MongoDB. Bad schema is the root cause of most MongoDB performance and cost issues—queries and indexes cannot fix a fundamentally wrong model.
Reference these guidelines when:
"Data that is accessed together should be stored together."
This is MongoDB's core philosophy. Embedding related data eliminates joins, reduces round trips, and enables atomic updates. Reference only when you must.
A core way to implement this philosophy is the fact that MongoDB exposes flexible schemas. This means you can have different fields in different documents, and even different structures. This allows you to model data in the way that best fits your access patterns, without being constrained by a rigid schema. For example, if different documents have different sets of fields, that is perfectly fine as long as it serves your application's needs. You can also use schema validation to enforce certain rules while still allowing for flexibility.
Another implication of the key principle is that information about the expected read and write workload becomes very relevant to schema design. If pieces of information from different entities are often queried or updated together, that means that prioritizing co-location of that data in the same document can lead to significant performance benefits. On the other hand, if certain pieces of information are rarely accessed together, it may make sense to store them separately to avoid loading more data than necessary.
$jsonSchema validator to catch invalid data at the database level (type checks, required fields, enum constraints, array size limits). Start with validationLevel: "moderate" and validationAction: "warn" on existing collections, then tighten to strict/error.$bsonSize.| Relationship | Cardinality | Access Pattern | Recommendation |
|---|---|---|---|
| One-to-One | 1:1 | Always together | Embed |
| One-to-Few | 1:N (N < 100) | Usually together | Embed array |
| One-to-Many | 1:N (N > 100) | Often separate | Reference |
| Many-to-Many | M:N | Varies | Two-way reference |
This is a rough guideline, and whether to embed or reference depends on your specific access patterns, data size, and read/write frequencies. Always verify with your actual workload.
Each reference file listed above contains detailed explanations and code examples. Use the descriptions in the Quick Reference to identify which files are relevant to your current task.
Each reference file contains:
For automatic verification, connect the MongoDB MCP Server.
If the MCP server is running and connected, I can automatically run verification commands to check your actual schema, document sizes, array lengths, index usage, and more. This allows me to provide tailored recommendations based on your real data, not just code patterns.
⚠️ Security: Use --readOnly for safety. Remove only if you need write operations.
When connected, I can automatically:
mcp__mongodb__collection-schemamcp__mongodb__aggregatemcp__mongodb__db-statsI will NEVER execute write operations without your explicit approval.
Before any write or destructive operation via MCP, I will: (1) summarize the exact operation (collection, index/validator, estimated number of docs affected), and (2) ask for explicit confirmation (yes/no). I will not proceed on partial or ambiguous approvals.
| Operation Type | MCP Tools | Action |
|---|---|---|
| Read (Safe) | find, aggregate, collection-schema, db-stats, count | I may run automatically to verify |
| Write (Requires Approval) | update-many, insert-many, create-collection | I will show the command and wait for your "yes" |
| Destructive (Requires Approval) | delete-many, drop-collection, drop-database | I will warn you and require explicit confirmation |
When I recommend schema changes or data modifications:
Your database, your decision. I'm here to advise, not to act unilaterally.
If you're not sure about a recommendation:
We're a team—let's get this right together.