> database-mongodb
Apply expert schema design, indexing, and performance rules for MongoDB. Use when designing MongoDB schemas, creating indexes, or optimizing NoSQL query performance. (triggers: **/*.ts, **/*.js, **/*.json, mongo, mongoose, objectid, schema, model)
curl "https://skillshub.wtf/HoangNguyen0403/agent-skills-standard/database-mongodb?format=md"MongoDB Best Practices
Priority: P0 (CRITICAL)
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).
Optimize Indexes
- ESR Rule: Equality, Sort, Range. Order your index keys
(status, date, price)if you querystatus='A', sort bydate, filterprice > 10.
See implementation examples for compound index and pagination patterns.
- 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.
Scale with Sharding
- 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.
Improve Query Performance
-
Cursor-Based Pagination: Use
_idor sort-key based pagination instead ofskip().skip(10000)scans 10000 docs. -
Aggregation: Prefer Aggregation Framework (
$match,$group) over bringing data to client (JS).
Configure Operations
- Write Concern: Understand
w:1(Ack) vsw:majority(Safe). - Transactions: Use only when ACID across multiple documents is stricter than performance needs.
Anti-Patterns
- No unbounded arrays: Use
$pushwith$sliceor redesign using the Bucket Pattern. - No client-side filtering: Project only needed fields; never fetch full docs to filter in memory.
- No deep nesting: Keep nesting ≤4 levels; flatten paths that are frequently queried.
References
> related_skills --same-repo
> common-store-changelog
Generate user-facing release notes for the Apple App Store and Google Play Store by collecting git history, triaging user-impacting changes, and drafting store-compliant changelogs. Enforces character limits (App Store ≤4000, Google Play ≤500), tone, and bullet format. Use when generating release notes, app store changelog, play store release, what's new, or version release notes for any mobile app. (triggers: generate changelog, app store notes, play store release, what's new, release notes, ve
> golang-tooling
Go developer toolchain — gopls LSP diagnostics, linting, formatting, and vet. Use when setting up Go tooling, running linters, or integrating gopls with Claude Code. (triggers: gopls, golangci-lint, golangci.yml, go vet, goimports, staticcheck, go tooling, go lint)
> common-ui-design
Design distinctive, production-grade frontend UI with bold aesthetic choices. Use when building web components, pages, interfaces, dashboards, or applications in any framework (React, Next.js, Angular, Vue, HTML/CSS). (triggers: build a page, create a component, design a dashboard, landing page, UI for, build a layout, make it look good, improve the design, build UI, create interface, design screen)
> common-owasp
OWASP Top 10 audit checklist for Web Applications (2021) and APIs (2023). Load during any security review, PR review, or codebase audit touching web, mobile backend, or API code. (triggers: security review, OWASP, broken access control, IDOR, BOLA, injection, broken auth, API review, authorization, access control)