Basic Mongodb Interview Questions

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

MongoDB Interview Questions & Answers

MongoDB has become one of the must skill set for MEAN stack and backend developers. MongoDB has proven
to be the most suited database for the modern applications. Also MongoDB fits well for the Agile methodology.
This tutorial presents you with almost all possible MongoDB Interview Questions for basic, intermediate and
advanced levels.

Basic MongoDB Interview Questions

What is MongoDB ?
MongoDB is a document based NoSQL Database.

Why is MongoDB, a NoSQL Database ?


A NoSQL Database is one that provides mechanism for storage and retrieval of data that is modeled in means
other than tabular relations. Since MongoDB provides a document based (which is again a set of key-value
pairs) that is schema-less, MongoDB is a NoSQL Database. And to mention, key-value stores are the simplest
NoSQL Databases and MongoDB is popular among them.

Could you mention some NoSQL Databases other than MongoDB ?


Yes. Of course, there are many. Some of the notable ones are Cassandra, HBASE, CouchDB, IBM Informix,
Azure DocumentDB, ToroDB etc.

What are the equivalents of Tables and Rows in SQL to that of MongoDB ?
MongoDB Collections could be considered as equivalent to Tables and MongoDB Documents could be
considered as equivalent to Row of SQL.

What specification does MongoDB Document follow ?


MongoDB Document follows BSON (Binary JSON) Specification.

What are the data types that are allowed for values in key:value pairs of
documents.
MongoDB Document follows BSON (Binary JSON) Specification. And the data types allowed are all those that
are specified in BSON specification.

What should be done when you have to work with large datasets and high data
throughput ?
MongoDB is horizontally scalable. If the application is expected to handle large datasets and high data
throughput, you may add required number of computers (/nodes) to the cluster.

Is there something like primary key in MongoDB ?


There is no concept of primary key in MongoDB. But there is a key:value pair with key as_id that is used to
store a unique value for each Document that is inserted to Collection. By default _id is populated by MongoDB.
But _id:value could be provided by user also, as long as the user provides unique value for _id.

Coming to Collections, do you think that they can be restricted in size ?


Yes. During the creation of collection, we may specify the size limit in Bytes, ie., the number of bytes that can
go into that collection. These are also called capped collections. And when we say size, it includes all the data
and metadata.

Is MongoDB fault tolerant ?


Yes. Data Redundancy could be achieved with the help of Replica Set. With MongoDB Replica Set, data could
be replicated over specified number of nodes in the cluster. And during that scenario, even if a node fails,
there are others with data replicated already. Although, it has to be noted that if a transaction is stored in a DB
and just before replicating it to others the node goes down, the transaction data is lost. This is unavoidable with
MongoDB.

Can MongoDB be used for real time analytics ?


Yes. MongoDB’s low latency and ability to analyze semi-structured or unstructured data make it as really a
good choice for real time analytics.

How is MongoDB better than Relational Databases ?


MongoDB has many benefits over Relational Databases, Some of them are :

MongoDB can handle structured data(like a spread-sheet or table), semi structured data and unstructured data (data with
no rules, examples are multimedia content).
All the NoSQL features of MongoDB makes it a perfect fit for Agile methodology during application development. Modern
applications are designed to have fewer development time and quick updates to the ever ending requirements.
MongoDB is horizontally scalable. Hence it can respond to the increasing application requirements with less hardware cost.

What is Replication in MongoDB ?


Replication is the process of making copies of data (documents) across multiple MongoDB instances. This
helps in failover scenarios. When a node goes down, the data is still present on the other nodes and can be
served without any application outage.

What is MapReduce in MongoDB ?


MapReduce is an algorithm used for deducing some useful information and trends from the available data. It is
generally used in data analytics associated with Big Data. MongoDB has the implementation of MapReduce
Algorithm and the funcitonality can be accessed through db.collection.mapReduce() .

What are the requirements that ring a bell to use MongoDB for an application ?
Try to answer the following questions, and if you get an YES for most of them, choose MongoDB.

1. Is your data structured or not ? Structured !


2. Does your application need scalability? horizontally in particular !
3. Do you want your schema design to be flexible ?
4. Does you data objects move around the application as JSON ?
5. You do not require JOINS on different collections ?

How do you start a Mongo Shell ?


Mongo Daemon should be started in prior.

To start Mongo Daemon, run the following command :

~$ sudo service
mongod start

~$ sudo service mongod start

Once Mongo Daemon is up and running, we can start a Mongo Shell using mongo command in terminal.

~$ mongo

~$ mongo

What is the default port on which Mongo Daemon starts ?


By default, unless modified through any means, Mongo Daemon starts on the port 12707 .

How do you connect to a Mongo instance running on another computer in the


network ?
Host and Port options of mongo command can be used to connect to mongod instance running on different
node connected to the network.
~$ <span class="c-
v">mongo</span> <sp
an class="c-o">--
</span><span
class="c-
~$ <span class="c-v">mongo</span> <span class="c-o">--</span><span class="c-v">host</span> <span class="c-
v">host</span> <span
o"><</span><span class="c-v">host</span><span class="c-o">></span> <span class="c-o">--</span><span class="c-
class="c-o"><</span>
<span class="c- <span class="c-o"><</span><span class="c-v">port_number</span><span class="c-o">></span>
v">port</span>
v">host</span><span
class="c-o">>
</span> <span
class="c-o">--</span>
<span class="c-
Can you run
v">port</span> multiple Mongo Instances on the same computer ?
<span
class="c-o"><</span>
Yes.class="c-
<span Using different port number for each Mongo Instance, multiple instances can be started.
v">port_number</span
><span class="c-o">>
</span>
Among the multiple Mongo Instances, how do you connect to a specific Mongo
Daemon instance ?
As Mongo Instances could be differentiated by port number, we can use the same information to start a mongo
shell with the --port option.

~$ <span class="c-
v">mongo </span>
<span class="c-o">--
</span><span
class="c-
~$ <span class="c-v">mongo </span><span class="c-o">--</span><span class="c-v">port</span> <span class="c-
v">port</span> <span
o"><</span><span class="c-v">port_number</span><span class="c-o">></span>
class="c-o"><</span>
<span class="c-
v">port_number</span
><span class="c-o">>
</span>
What is a MongoDB Database ?
In MongoDB, Database is a collection of MongoDB Collections.

Tutorial – MongoDB Database.

How do you start working on a specific MongoDB Database through mongo shell
?
use <database_name> command in mongo shell can be used to connect to a specific MongoDB Database.

What is the command to list available Databases in a MongoDB instance ?


To get the list of databases, open Mongo Shell and run the show dbs command.

How do you create a MongoDB Database ?


MongoDB Database can be created through Mongo Shell using use <database_name> command. If the
database_name provided to the use command does not exist, a new database is created. Technically, a
database is not created until a document is inserted to a collection in the database.

How to create a MongoDB Collection ?


Once we select a database using use <database_name> command, to create a collection use db.
<collection_name> to reference a collection. If the collection is already not present, a new Collection is
created.

How do you explicitly create a MongoDB Collection ?


db.createCollection(<collection_name>, [options]) command can be used to create a collection explicitly with
the configuration options provided.

Which command is used to show all collections in a MongoDB Database ?


First we need to select the database. Then we can use show collections in Mongo Shell to list all MongoDB
Collections present in a MongoDB Database.

How to delete a MongoDB Collection ?


drop() function can be called on the collection to delete it. Following is the syntax :

db.
<collection_name>.dro
p()

db.<collection_name>.drop()

Upon successful deletion, the command echoes back true to the prompt.

What happens when you try delete a Collection that does not exist ?
db.<collection_name>.drop() command returns false .

What is a Document in MongoDB ? Give us a sample.


Document is an entity in which zero or more ordered field-value pairs are stored.

Following is a sample MongoDB Document :

{
name: "Robin",
age: 23,
place: "New York",
{ hobbies: ["Singing",
"Reading Books"]
} name: "Robin",
age: 23,
place: "New York",
hobbies: ["Singing", "Reading Books"]
}

Can Documents be nested ?


Yes. They can. Documents support nesting.

Intermediate MongoDB Interview Questions

Advanced MongoDB Interview Questions

MongoDB Tutorial

⊩ MongoDB Tutorial

⊩ Install MongoDB on Ubuntu

⊩ Start MongoDB Server

⊩ MongoDB Shell

⊩ Check MongoDB Version

⊩ MongoDB Server Port Number - Default Value and How to Change it

⊩ MongoDB Script

Database

⊩ MongoDB Database

⊩ MongoDB Create Database

⊩ MongoDB Delete Database

Collections

⊩ MongoDB Collection

⊩ MongoDB Create Collection

⊩ MongoDB Delete Collection

Documents

⊩ MongoDB Document

⊩ MongoDB Insert Document

⊩ MongoDB Query Documents

⊩ MongoDB Project Fields in Result

⊩ MongoDB Update Document

⊩ MongoDB Delete Document

⊩ MongoDB Limit Documents

⊩ MongoDB Skip Documents

⊩ MongoDB Sort Documents

⊩ MongoDB Setup Replica Set

⊩ MongoDB Locks
⊩ MongoDB Locks

MongoDB Concepts

⊩ MongoDB Text Search

⊩ MongoDB MapReduce

⊩ MongoDB Backup - mongodump

MongoDB Queries

⊩ MongoDB Date

MongoDB Queries

⊩ MongoDB Date()

MongoDB Integration
MongoDB Java

⊩ Connect to MongoDB from Java

MongoDB Python

⊩ Connect to MongoDB from Python

MongoDB Kotlin

⊩ Connect to MongoDB from Kotlin

MongoDB Node.js

⊩ Node.js MongoDB

⊩ Node.js MongoDB Connection

⊩ Node.js MongoDB Create Database

⊩ Node.js MongoDB Drop Database

⊩ Node.js MongoDB Create Collection

⊩ Node.js MongoDB Delete Collection

⊩ Node.js MongoDB Insert Documents

⊩ MongoError: failed to connect to server

MongoDB Others

⊩ MongoDB Interview Questions

⊩ Uninstall MongoDB from Ubuntu

Useful Resources

⊩ How to Learn Programming

You might also like