📖 Guide

MongoDB — Complete Reference

MongoDB cheat sheet covering CRUD operations, query and update operators, aggregation pipeline, indexes, and administration.

91 commands across 10 categories

Database Operations

CommandDescription
mongosh
Open the MongoDB shell (mongosh)
show dbs
List all databases
use mydb
Switch to a database (creates if it doesn't exist)
db
Show the current database name
db.dropDatabase()
Drop the current database
db.stats()
Get database statistics (size, collections, objects)
db.getMongo()
Get connection info for the current session
show collections
List all collections in the current database

CRUD

CommandDescription
db.users.insertOne({ name: 'Alice', age: 30 })
Insert a single document
db.users.insertMany([{ name: 'Bob' }, { name: 'Carol' }])
Insert multiple documents
db.users.findOne({ name: 'Alice' })
Find the first matching document
db.users.find({ age: { $gte: 18 } })
Find all matching documents
db.users.find().sort({ age: -1 }).limit(10)
Sort descending and limit results
db.users.countDocuments({ active: true })
Count matching documents
db.users.updateOne({ name: 'Alice' }, { $set: { age: 31 } })
Update the first matching document
db.users.updateMany({ active: false }, { $set: { archived: true } })
Update all matching documents
db.users.replaceOne({ name: 'Alice' }, { name: 'Alice', age: 31 })
Replace an entire document
db.users.deleteOne({ name: 'Alice' })
Delete the first matching document
db.users.deleteMany({ archived: true })
Delete all matching documents
db.users.findOneAndUpdate({ name: 'Bob' }, { $inc: { score: 1 } }, { returnDocument: 'after' })
Find, update, and return the modified document

Query Operators

CommandDescription
{ age: { $eq: 25 } }
Equal to (implicit with { age: 25 })
{ age: { $gt: 18, $lt: 65 } }
Greater than / less than
{ status: { $in: ['active', 'pending'] } }
Match any value in array
{ status: { $nin: ['deleted'] } }
Match none of the values in array
{ $and: [{ age: { $gte: 18 } }, { active: true }] }
Logical AND (implicit when using multiple fields)
{ $or: [{ age: { $lt: 18 } }, { role: 'admin' }] }
Logical OR
{ email: { $exists: true } }
Field exists (or doesn't with false)
{ name: { $regex: /^A/i } }
Regular expression match (case-insensitive)
{ tags: { $all: ['js', 'node'] } }
Array contains all specified elements
{ 'address.city': 'Vienna' }
Query nested document fields with dot notation

Update Operators

CommandDescription
{ $set: { name: 'Alice' } }
Set a field value (create if doesn't exist)
{ $unset: { tmpField: '' } }
Remove a field from the document
{ $inc: { count: 1 } }
Increment a numeric field
{ $mul: { price: 1.1 } }
Multiply a numeric field
{ $rename: { 'old': 'new' } }
Rename a field
{ $push: { tags: 'new-tag' } }
Add an element to an array
{ $addToSet: { tags: 'unique-tag' } }
Add to array only if not already present
{ $pull: { tags: 'old-tag' } }
Remove matching elements from an array
{ $pop: { tags: 1 } }
Remove last element from array (1) or first (-1)
{ $currentDate: { updatedAt: true } }
Set field to current date

Aggregation Pipeline

CommandDescription
db.orders.aggregate([{ $match: { status: 'completed' } }])
Filter documents (like find)
{ $group: { _id: '$category', total: { $sum: '$amount' } } }
Group by field and calculate aggregates
{ $sort: { total: -1 } }
Sort results (1 ascending, -1 descending)
{ $project: { name: 1, total: 1, _id: 0 } }
Include/exclude specific fields
{ $limit: 10 }
Limit the number of results
{ $skip: 20 }
Skip a number of documents (pagination)
{ $unwind: '$items' }
Deconstruct an array field into separate documents
{ $lookup: { from: 'users', localField: 'userId', foreignField: '_id', as: 'user' } }
Left outer join with another collection
{ $addFields: { fullName: { $concat: ['$first', ' ', '$last'] } } }
Add computed fields to documents
{ $count: 'totalResults' }
Count and return total number of documents

Indexes

CommandDescription
db.users.createIndex({ email: 1 })
Create an ascending index on a field
db.users.createIndex({ email: 1 }, { unique: true })
Create a unique index
db.users.createIndex({ name: 1, age: -1 })
Create a compound index
db.users.createIndex({ bio: 'text' })
Create a text search index
db.places.createIndex({ location: '2dsphere' })
Create a geospatial index
db.users.createIndex({ createdAt: 1 }, { expireAfterSeconds: 86400 })
TTL index — auto-delete documents after 24 hours
db.users.getIndexes()
List all indexes on a collection
db.users.dropIndex('email_1')
Drop an index by name
db.users.find({ email: 'a@b.com' }).explain('executionStats')
Analyze query performance and index usage

Collection Management

CommandDescription
db.createCollection('logs', { capped: true, size: 10485760 })
Create a capped collection (10 MB)
db.users.drop()
Drop a collection
db.users.renameCollection('members')
Rename a collection
db.users.estimatedDocumentCount()
Fast approximate document count
db.users.distinct('city')
Get unique values for a field
db.users.find().forEach(printjson)
Iterate and print all documents
db.users.bulkWrite([{ insertOne: { document: { name: 'X' } } }])
Execute multiple write operations in bulk
db.users.createIndex({ name: 1 }, { collation: { locale: 'en', strength: 2 } })
Case-insensitive index with collation

Users & Roles

CommandDescription
db.createUser({ user: 'admin', pwd: 'pass', roles: ['root'] })
Create a database user with a role
db.createUser({ user: 'app', pwd: 'pass', roles: [{ role: 'readWrite', db: 'mydb' }] })
Create a user with specific database access
db.getUsers()
List all users in the current database
db.updateUser('app', { roles: [{ role: 'read', db: 'mydb' }] })
Update user roles
db.changeUserPassword('app', 'newpass')
Change a user's password
db.dropUser('app')
Delete a user
db.auth('admin', 'pass')
Authenticate in the current session

Replica Sets

CommandDescription
rs.status()
Get replica set status and member states
rs.initiate()
Initialize a new replica set
rs.add('mongo2:27017')
Add a member to the replica set
rs.remove('mongo2:27017')
Remove a member from the replica set
rs.conf()
Get the replica set configuration
rs.stepDown()
Force the primary to step down
db.getMongo().setReadPref('secondaryPreferred')
Set read preference to secondary nodes
mongodump --uri='mongodb://host:27017/mydb' --out=./backup
Backup a database
mongorestore --uri='mongodb://host:27017/mydb' ./backup/mydb
Restore a database from backup

Common Patterns

CommandDescription
db.users.findOne({ _id: ObjectId('...') })
Query by document ID
db.users.find({}, { name: 1, email: 1, _id: 0 })
Projection — return only specific fields
db.users.find().sort({ createdAt: -1 }).skip(20).limit(10)
Pagination pattern
db.orders.aggregate([{ $group: { _id: null, avg: { $avg: '$total' } } }])
Calculate the average of a field
db.users.updateOne({ _id: id }, { $set: data }, { upsert: true })
Upsert — insert if not found, update if exists
db.events.find({ date: { $gte: ISODate('2024-01-01') } })
Query by date range
db.products.find({ $text: { $search: 'coffee organic' } })
Full-text search (requires text index)
db.places.find({ loc: { $near: { $geometry: { type: 'Point', coordinates: [16.37, 48.21] } } } })
Find documents near a geo point

More Guides

🌿
Git Commands
Complete Git command reference — from basics to advanced workflows. Searchable, with examples.
📝
Vim Commands
Complete Vim/Vi command reference — modes, motions, editing, search, and advanced features.
🐳
Docker Commands
Complete Docker & Docker Compose command reference — containers, images, volumes, networks, and orchestration.
🔤
Regex Reference
Complete regular expression reference — syntax, patterns, quantifiers, groups, lookaheads, and common recipes.
🐧
Linux Commands
Complete Linux/Bash command reference — file management, text processing, networking, system admin, and shell scripting.
☸️
Kubernetes Commands
Complete Kubernetes & kubectl command reference — pods, deployments, services, configmaps, and cluster management.
🐍
Python Reference
Complete Python reference — syntax, data structures, string methods, file I/O, comprehensions, and common patterns.
🗃️
SQL Reference
Complete SQL reference — queries, joins, aggregation, subqueries, indexes, and database management.
🌐
Nginx Reference
Complete Nginx configuration reference — server blocks, locations, proxying, SSL, load balancing, and caching.
🔐
SSH Commands
Complete SSH reference — connections, key management, tunneling, config, SCP/SFTP, and security hardening.
👷
Jenkins Reference
Complete Jenkins reference — pipeline syntax, Jenkinsfile, plugins, CLI, agents, and CI/CD patterns.
📨
HTTP Headers Reference
Complete HTTP headers reference — request headers, response headers, caching, security, CORS, and content negotiation. Searchable, with examples.
🐘
PostgreSQL Reference
Comprehensive PostgreSQL reference — from connection basics to advanced features like JSONB, full-text search, window functions, and performance tuning.
Async Patterns Reference
Multi-language async/concurrency patterns — JavaScript, Python, Go, Rust, Java, and universal concurrency patterns.
📡
Protobuf & gRPC Reference
Comprehensive reference for Protocol Buffers (proto3) and gRPC — message definitions, services, streaming, and common patterns.
📚
JS Array Methods
Complete JavaScript Array methods reference — creating, searching, transforming, sorting, iterating, and common patterns. Searchable, with examples.
🌊
Tailwind CSS Reference
Complete Tailwind CSS reference — layout, spacing, typography, colors, responsive design, states, and common patterns. Searchable, with examples.
GraphQL Reference
Complete GraphQL reference — schema definition, types, queries, mutations, directives, fragments, and common patterns. Searchable, with examples.
💻
VS Code Shortcuts
Complete VS Code keyboard shortcuts — editing, navigation, search, multi-cursor, terminal, debug, and more. Searchable, with Cmd/Ctrl notation.
🔲
CSS Grid Reference
Complete CSS Grid reference — container properties, item placement, grid functions, and common layout patterns. Searchable, with examples.
📦
CSS Flexbox Reference
Complete CSS Flexbox reference — container properties, item properties, and common layout patterns. Searchable, with examples.
⚛️
React Hooks Reference
Complete React Hooks reference — useState, useEffect, useContext, custom hooks, and common patterns. Searchable, with examples.
🔷
TypeScript Reference
Complete TypeScript reference — types, interfaces, generics, utility types, and advanced patterns. Searchable, with examples.
☁️
AWS CLI Reference
Complete AWS CLI reference — EC2, S3, IAM, Lambda, ECS, RDS, CloudFormation, and common operations.
🐹
Go Reference
Complete Go (Golang) reference — syntax, types, functions, concurrency, error handling, and common patterns.
💠
PowerShell Reference
Complete PowerShell reference — cmdlets, pipelines, scripting, file operations, remote management, and Active Directory.
💾
Redis Commands
Complete Redis command reference — strings, hashes, lists, sets, sorted sets, pub/sub, transactions, and server management.
🏗️
Terraform Commands
Complete Terraform reference — init, plan, apply, state management, modules, workspaces, and HCL syntax.
⚙️
Ansible Commands
Complete Ansible reference — playbooks, modules, inventory, roles, vault, and ad-hoc commands.
🟨
JavaScript
Complete JavaScript reference — variables, types, operators, strings, arrays, objects, functions, async, DOM, ES6+, and more.
🎨
CSS
Complete CSS reference — selectors, box model, positioning, typography, animations, media queries, custom properties, and more.
📄
HTML
Complete HTML reference — document structure, text content, forms, media, semantic elements, accessibility, and more.
Java
Complete Java reference — data types, strings, collections, OOP, interfaces, exceptions, file I/O, streams, lambdas, and more.
💻
Bash
Complete Bash reference — variables, strings, arrays, conditionals, loops, functions, file tests, I/O redirection, process management, and more.
🦀
Rust
Comprehensive Rust language cheat sheet covering ownership, traits, pattern matching, concurrency, and more.
📝
Markdown
Complete Markdown syntax reference for headings, formatting, links, tables, code blocks, and extensions.
📋
YAML
YAML syntax reference covering scalars, collections, anchors, multi-line strings, and common patterns.
🌐
Curl
Curl command-line reference for HTTP requests, authentication, file transfers, debugging, and common API patterns.
Cron
Cron scheduling reference covering syntax, field values, crontab management, and common schedule patterns.
🖥️
Tmux
Terminal multiplexer for managing multiple sessions, windows, and panes from a single terminal.
🔧
Awk
Powerful text processing language for pattern scanning, data extraction, and report generation.
✂️
Sed
Stream editor for filtering and transforming text, line by line.
🔍
Find
Search for files and directories in a directory hierarchy with powerful filtering options.
🔎
Grep
Search text using patterns. Filter lines from files, command output, or streams with regular expressions.
🐘
PHP
Complete PHP cheat sheet covering syntax, OOP, arrays, PDO, and modern PHP 8.x features.
⚙️
C
Complete C programming cheat sheet covering syntax, pointers, memory management, and standard library.
🔷
C++
Complete C++ cheat sheet covering STL containers, OOP, templates, smart pointers, and modern C++ features.
🐬
MySQL
Complete MySQL cheat sheet covering queries, joins, indexes, transactions, and administration.
💅
Sass
Complete Sass/SCSS cheat sheet covering variables, mixins, functions, nesting, and modern module system.
🔐
Chmod
Linux file permission commands and patterns for chmod.
🔢
NumPy
Essential NumPy commands for array manipulation and numerical computing in Python.
🐼
Pandas
Pandas cheat sheet for data manipulation, analysis, and transformation in Python.
🎯
Dart
Dart language cheat sheet covering syntax, types, OOP, null safety, and async patterns.
🔺
Laravel
Laravel PHP framework cheat sheet for routing, Eloquent, Blade, Artisan, and more.
🟩
Node.js
Comprehensive Node.js runtime reference covering modules, file system, HTTP, streams, and more.
Next.js
Next.js App Router reference covering routing, data fetching, server components, and deployment.
🔥
Firebase
Firebase reference covering Authentication, Firestore, Realtime Database, Cloud Functions, and Hosting.
🐳
Docker Compose
Docker Compose reference covering CLI commands, service configuration, networking, volumes, and more.
💲
jQuery
Quick reference for jQuery selectors, DOM manipulation, events, AJAX, and more.
📐
LaTeX
Quick reference for LaTeX document structure, math mode, formatting, and common packages.
🎯
XPath
Quick reference for XPath expressions, axes, predicates, and functions for XML/HTML querying.
Emmet
Quick reference for Emmet abbreviations for lightning-fast HTML and CSS coding.
📦
TOML
Quick reference for TOML configuration file syntax, types, tables, and common patterns.
💎
Prisma
Complete Prisma ORM cheat sheet — schema, queries, migrations, and CLI.
🤖
GitHub Actions
Complete GitHub Actions cheat sheet — workflows, triggers, jobs, and CI/CD patterns.
📦
npm
Complete npm cheat sheet — package management, scripts, publishing, and configuration.
Supabase
Complete Supabase cheat sheet — auth, database, realtime, storage, and edge functions.
🪶
Apache
Complete Apache HTTP Server cheat sheet — virtual hosts, modules, rewrite rules, and SSL.
📡
HTTP Status Codes
Complete reference of all standard HTTP response status codes with descriptions and use cases.
🔤
ASCII Table
Complete ASCII character reference with decimal, hexadecimal, and character values.
🔧
Chrome DevTools
Essential Chrome DevTools shortcuts, commands, and workflows for web developers.
💧
Drizzle ORM
Complete Drizzle ORM reference for schema definition, queries, relations, migrations, and common patterns.
Vercel CLI
Complete Vercel CLI reference for deployment, project management, domains, environment variables, and configuration.
🔄
PM2
Production process manager for Node.js applications with built-in load balancer, monitoring, and zero-downtime reloads.
📺
Screen
GNU Screen terminal multiplexer for persistent sessions, window management, and remote work.
📦
Webpack
Module bundler for JavaScript applications — loaders, plugins, code splitting, optimization, and dev server.
Vite
Next-generation frontend build tool with instant HMR, native ES modules, and optimized production builds via Rollup.

📖 Free, searchable command reference. Bookmark this page for quick access.