Skip to main content

๐Ÿ”ฅ MongoDB Index Types Explained — With Real Examples, Colors & Interview Tips

๐Ÿƒ What is MongoDB?

MongoDB is a NoSQL document-based database that stores data in JSON-like format. Instead of rows and columns, it uses collections and documents. This makes it super flexible and schema-less — perfect for fast-moving modern apps ๐Ÿš€.

๐Ÿ’ก Difference vs SQL Databases:
SQL = Tables, Rows, Columns ๐Ÿ“Š
MongoDB = Collections, Documents ๐Ÿ“š

❓Why Indexes Matter

Imagine searching a phonebook without alphabetical order — painful, right? ๐Ÿ˜… Indexes make your searches faster by letting MongoDB skip scanning every document.

⚡ Tip: Without indexes, MongoDB performs a collection scan — meaning it checks every record. That’s fine for 10 docs... not for 10 million!

๐Ÿง  Types of Indexes in MongoDB

1️⃣ Single Field Index

Most basic and common. You index one field.

db.users.createIndex({ "name": 1 })

1 = ascending, -1 = descending. Used for queries like { name: "Priya" }.

2️⃣ Compound Index

Multiple fields combined to improve multi-field queries.

db.orders.createIndex({ "customerId": 1, "orderDate": -1 })

Order of fields matters! MongoDB can use prefix fields efficiently.

3️⃣ Text Index

Used for searching text phrases in string fields — supports partial matches and relevance scoring.

db.blogs.createIndex({ "content": "text", "title": "text" })

Then query like:

db.blogs.find({ $text: { $search: "MongoDB index" } })

4️⃣ Multikey Index

When field is an array — MongoDB indexes each array element.

db.products.createIndex({ "tags": 1 })

Query example: db.products.find({ tags: "database" })

5️⃣ Hashed Index

Distributes values evenly for sharding or hashed lookups.

db.users.createIndex({ "email": "hashed" })

6️⃣ TTL (Time-To-Live) Index

Auto-deletes documents after a given time — perfect for logs, sessions ⏳.

db.sessions.createIndex({ "createdAt": 1 }, { expireAfterSeconds: 3600 })

7️⃣ Geospatial Index

Used for location-based queries ๐Ÿ“.

db.places.createIndex({ location: "2dsphere" })

8️⃣ Wildcard Index

For dynamic fields when you don’t know which ones to index.

db.dynamic.createIndex({ "$**": 1 })

9️⃣ Unique Index

Ensures values are not duplicated.

db.users.createIndex({ "email": 1 }, { unique: true })

๐Ÿ”Ÿ Partial / Sparse Index

Indexes only documents meeting a condition (saves space!).

db.users.createIndex({ age: 1 }, { partialFilterExpression: { age: { $gte: 18 } } })

๐Ÿ“Š Quick Comparison Table

Index TypeUse CaseExample
SingleOne field{ name: 1 }
CompoundMulti-field queries{ age:1, city:1 }
TextText search{ title:"text" }
HashedSharding / random lookup{ id:"hashed" }
TTLAuto delete{ createdAt:1 }

๐ŸŽฏ Real Example — Speed Boost!

Query before index:

db.users.find({ name: "Priya" })

Took 2.3 sec ⏳

After index:

db.users.createIndex({ name: 1 })

Took 0.02 sec ⚡

๐Ÿ—ฃ️ Interview Quickfire Q&A

  • ๐Ÿ’ฌ Q: What’s the default index in MongoDB?
    A: The _id field — automatically indexed!
  • ๐Ÿ’ฌ Q: How is text index different from search index?
    A: Text index = keyword search. Search index (Atlas Search) = full Lucene-based search engine with scoring.
  • ๐Ÿ’ฌ Q: Can we have multiple text indexes per collection?
    A: Nope ❌ Only one text index allowed per collection.

๐Ÿ Conclusion

Indexes are the superpower of MongoDB ⚙️ — they turn slow lookups into lightning-fast queries ⚡. But use wisely: too many indexes = slower writes.

๐Ÿ’š Pro Tip: Always check your queries with db.collection.explain("executionStats") to see if an index is actually used.

๐Ÿš€ Keep learning, keep indexing smart! ๐Ÿƒ

Comments

Popular posts from this blog

๐Ÿ” Is final Really Final in Java? The Truth May Surprise You ๐Ÿ˜ฒ

๐Ÿ’ฌ “When I was exploring what to do and what not to do in Java, one small keyword caught my eye — final . I thought it meant: locked, sealed, frozen — like my fridge when I forget to defrost it.”   But guess what? Java has its own meaning of final… and it’s not always what you expect! ๐Ÿ˜… Let’s break it down together — with code, questions, confusion, jokes, and everything in between. ๐ŸŽฏ The Confusing Case: You Said It's Final... Then It Changed?! ๐Ÿซ  final List<String> names = new ArrayList <>(); names.add( "Anand" ); names.add( "Rahul" ); System.out.println(names); // [Anand, Rahul] ๐Ÿคฏ Hold on... that’s final , right?! So how on earth is it still changing ? Time to dive deeper... ๐Ÿง  Why Is It Designed Like This? Here’s the key secret: In Java, final applies to the reference , not the object it points to . Let’s decode this like a spy mission ๐Ÿ•ต️‍♂️: Imagine This: final List<String> names = new ArrayList <>(); Be...

๐ŸŒŸ My Journey – From Zero to Senior Java Tech Lead ๐ŸŒŸ

 There’s one thing I truly believe… If I can become a Java developer, then anyone in the world can. ๐Ÿ’ฏ Sounds crazy? Let me take you back. ๐Ÿ•“ Back in 2015… I had zero coding knowledge . Not just that — I had no interest in coding either. But life has its own plans. In 2016, I got a chance to move to Bangalore and joined a Java course at a training center. That’s where it all started — Every day, every session made me feel like: "Ohhh! Even I can be a developer!" That course didn’t just teach Java — it gave me confidence . ๐Ÿงช Two Life-Changing Incidents 1️⃣ The Interview That Wasn't Planned Halfway through my course, I had to urgently travel to Chennai to donate blood to a family member. After that emotional rollercoaster, I found myself reflecting on my skills and the future. The next day, as I was preparing for my move to Bangalore to complete the remaining four months of my course, I randomly thought — "Let me test my skills... let me just see...

๐ŸŽข Java Loops: Fun, Fear, and ForEach() Fails

๐ŸŒ€ Oops, I Looped It Again! — The Ultimate Java Loop Guide You Won't Forget “I remember this question from one of my early interviews — I was just 2 years into Java and the interviewer asked, ‘Which loop do you prefer and why?’” At first, I thought, “Duh! for-each is cleaner.” But then he grilled me with cases where it fails. ๐Ÿ˜ต That led me to explore all loop types, their powers, and their pitfalls. Let’s deep-dive into every major Java loop with examples &  real-world guidance so you'll never forget again. ๐Ÿ” Loop Type #1: Classic For Loop — “The Old Reliable” ✅ When to Use: You need an index You want to iterate in reverse You want full control over loop mechanics ✅ Good Example: List<String> names = List.of("A", "B", "C"); for (int i = 0; i < names.size(); i++) { System.out.println(i + ": " + names.get(i)); } ๐Ÿ”ฅ Reverse + Removal Example: List<String> item...