0 ratings 0% found this document useful (0 votes) 25 views 28 pages Mongodb
The document provides an introduction to MongoDB and NoSQL databases, highlighting their differences from traditional SQL databases. It covers key concepts such as types of NoSQL databases, features of MongoDB, and basic commands for database management. Additionally, it discusses the use cases for NoSQL, MongoDB's data types, and tools like MongoDB Compass and Atlas.
AI-enhanced title and description
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, 
claim it here .
Available Formats
Download as PDF or read online on Scribd
Go to previous items Go to next items 
Introduction to
MongoDB
mongoDB.Agenda
Introduction to MongoDB
» What is NoSQL?
» Types of NoSQL
» SQL Vs NoSQL
» When to use NoSQL?
» What is MongoDB?
> Features of MongoDB
» MongoDB Data types
> Who's using MongoDB?
> MongoDB terms
» MongoDB Installation
» Some MongoDB commands
» MongoDB Compass & MongoDB
Atlas
» ReferencesWhat is NoSQL Database?
» The term “NoSQL database’ refer to any “Non-relational” or “Not only SQL” databases
provides a mechanism for storage and retrieval of data in a format other than tabular relations
model used in relational databases.
> NoSQL database doesn't use tables for storing data,
» Itis generally used to store big data and real-time web applications.
> Flexible schema i.e., no predefined or rigid schema.
> Itavoids joins and is easy to scale.
Introduction to MongoDB 3Types of NoSQL Database
NoSQL Databases are mainly categorized into four types: Key-value pair, Column-oriented,
Graph-based & Document-oriented.
 
Example
Preto Example
ro Neo, nfoGi,nfinte
Desc Graph, Flock DB
   
Introduction to MongoDB 4SQL Vs NoSQL
———q~——
Introduc
SQL databases are primarily called
RDBMS or Relational Databases.
‘SQL databases are table-based
databases.
Vertical Scalability
Fixed or Predefined schema.
Not suitable for hierarchical data storage.
Oracle, MySQL, Microsoft SQL Server,
and PostgreSQL.
NoSQL databases are primarily called
as Non-relational or distributed
database.
NoSQL databases can be document
based, key-value pairs, graph
databases.
Horizontal Scalability
Flexible schema.
Suitable for hierarchical data storage.
Document: MongoDB and CouchDB,
Key-value: Redis and DynamoDB,
Column-based: Cassandra and HBase,
Graph: Neo4j and Amazon Neptune.When to use NoSQL?
1. When a huge amount of data needs to be stored and retrieved.
2. The relationship between the data you store is not that important
3. The data changes over time and is not structured.
4. Constraints and Joins support is not required at database level.
5. The data is growing continuously, and you need to scale the database regularly to handle
the data.
Introduction to MongoDBWhat is MongoDB?
» Most popular NoSQL database.
> Open-source document-oriented database.
> Its scale-out architecture allows you to meet the
increasing demand for your system by adding
more nodes to share the load.
» MongoDB uses BSON (Binary JSON) to query
database.
 
» Stores data in the form of BSON documents.
Introduction to MongoDB, 7Features of MongoDB
> Indexing: Efficient search & data processing in very less time.
> Scalability: MongoDB scales horizontally using sharding (partitioning data across various
servers). Also, new machines can be added to a running database.
> Replication & High Availability: Multiple copies of data is replicated on different servers
which protects the database from hardware failures. If one server goes down, the data can
be retrieved easily from other active servers which also had the data stored on them.
> Load balancing: It has an automatic load balancing configuration because of data placed in
shards.
» Aggregation: Aggregation operations process data records and return the computed
fesults. It is like the GROUPBY clause in SQL. A few aggregation expressions are sum, avg,
min, max, etc.
> Languages supported: The list of supported languages includes Node,js, C, C++,
C#, Go, Java, Perl, PHP, Python, Ruby, Rust, Scala, and Swift.
Introduction to MongoDBMongoDB Data Types
$ String Null
‘Integer * Symbol
‘Boolean ‘ Date
* Double * Object ID
 Min/ Max keys ‘ Binary data
“Arrays "Code
Timestamp * Regular expression
Object
Introduction to MongoDBWho’s is using MongoDB?
MongoDB has been adopted as backend software by a few major websites and services
including Toyota, Cisco, Shutterfly, Adobe, Ericsson, Craigslist, eBay, and Foursquare.
Leading Organizations Rely on MongoDB
BUY Metlife viacom @uayem ebay
encssonZ $6 aeXeotrktins FY O, ZA
 
guardian GOGO) radian’ @ Forbes
McAfee ssrazorec? insiben © Harmony’
github shuttewiy® inturt @p argue Tima GILT
‘UsdS itty «= PEARSON = AD) craigstist
Introdution to MongoDB 10MongoDB Terms
» Databases: A database stores one or more collections of documents.
» Collections: MongoDB stores documents in collections. Collections are analogous to tables
in relational databases.
> Documents: MongoDB stores data records as BSON documents & similar to JSON
objects. It is analogous to row in relational databases. These are composed of field-and-value
pairs and have the following structure:
field1: value1,
field2: value2,
field3: value3,
fieldN: valueN
» Fields Names: These are strings analogous to column in relational databases.
Introduction to MongoDB 1Example
{
name: "sue",
age: 26,
status: *A",
groups: [ "news", "sports" ]
Introduction to MongoDB
<+— field: value
<— field: value
+— field: value
+— field: valueSQL Vs MongoDB Terms
SQL Term MongoDB Term
Database Database
Table Collection
Index Index
Row BSON document.
Column BSON field
Primary Key _id field
Group by Aggregation
Join Embedding and Linking _
 
Introduction to MongoDB 13MongoDB Installation
> MongoDB is available in two server editions: Community and Enterprise.
> Community edition is free & Enterprise edition is a paid version and has some advanced
features.
» Installation links:
Community:
Enterprise:
Introduction to MongoDBCreate Database
The use Database_name command makes a new database in the system if it does not exist, if
the database exists it uses that database.
For example, use mydb.
Now your database is ready of name mydb.
|
EPA
 
Introduction to MongoDBList all databases
To list down all the databases, use the command below:
show dbs
This command lists down all the databases and their size on the disk.
 
mydb database is not created until you save a document in it.
Introduction to MongoDBCreate Collection
To create collection, use the command below:
db.createCollection(name, options)
name is name of collection to be created. Options is a document and is used to specify
configuration of collection such as capped, autolndexld, size.
 
Introduction to MongoDBList all Collections
To see all collections in a database, use the command below:
show collections
PT may easy
Lig
ey
 
Introduction to MongoDBDrop Database & Collection
> Use the following command to delete a database:
db.dropDatabase()
» Use the following command to delete a collection:
db.collection_name.drop()
 
Introduction to MongoDBCreate Documents
Two methods insert or create documents in collection:
1. db.collection_name.insertOne()
2. db.collection_name.insertMany()
chau.)Retrieving Documents
» Use the below command to retrieve documents:
db.collection_name.find()
» Fora proper formatted output, use the below command: pretty() with find().
db.collection_name.find().pretty()
 
Introduction to MongoDBRetrieving Documents
 
Introduction to MongoDBRetrieving Documents with Filters orUpdate Documents
> There are 2 ways to update documents:
1. db.collection_name.updateOne()
2. db.collection_name.updateMany()
eet,
 
Introduction to MongoUpdate Documents
COM rs ane CT
Eras eg
Sieciacs.) Cran
Ce esa
Dera tse
Peg et
Introduction to MongoDB
2) .pretty()
 
BDelete Documents
> There are 2 ways to delete documents:
1. db.collection_name.deleteOne()
2. db.collection_name.deleteMany()
eee
rrr
Introduction to MongoDB
{age:23})
BRCM OCC cr
Seer
mere)
ind().pretty()
re)
Cora acts
suis
CnMongoDB Compass & MongoDB Atlas
> MongoDB Compass is a powerful GUI for querying, aggregating, and analyzing your
MongoDB data in a visual environment. It is free to use and can be run on macOS,
Windows, and Linux.
» Installation link:
» MongoDB Atlas is a multi-cloud database service by the same people that build MongoDB
It makes easy to deploy and manage databases on-demand when and where you need
them.
Introduction to MongoDB aThank you