Notes Chapter 20 Basics of NoSQL Databases MongoDB
Introduction
- Till now we have been working on the databases which were based on SQL consisting of table, row, fields ,records etc.
- It is possibe to have database without any structure or record. NoSQL or Not Only SQL Databases are such databases.
- We will learn NoSQL databases in this chapter.
NoSQL Databases
- These are non-relational databases which does not have any strict or rigid structure.
- These does not store records on the basis of conventional tables.
- These runs in clusters and stores data on the basis of web.
- These are high in scalability. These are also known as bigdata.
- You have worked on several apps/web apps using such databases like Google Mail, Google Earth, Ebay, LinkedIn, facebook, Amazon etc.
- These provides fast response time.
- These can handle data of any kind without any restriction.
- These adopts new features and fast update.
- These does not show down time.
Types of NoSQL Databases
1. Key-value Databases
2. Document Databases
3. Column family stores Databases
4. Graph Databases
Key-Value databases
- Just like python dictionary.
- Very simple and flexible.
- Examples-Cassandra, Amazon DyanmoDB,
ATS (Azure Table Storage, Riak, BerkeleyDB
data:image/s3,"s3://crabby-images/cc2da/cc2da64fca4e04703c009493179b3d50ccdd1371" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Document Databases
- These are advanced form of key-value databases.
- Here, key-value pair stores in document in structured or semi-structured form.
- Keys are always of string type, values can be of any type.
- It can be in the form of MS office document, PDFs, XML, JSON ,BSON.
- JSON (JavaScript Object Notation) and BSON (Binary JSON)
- JSON is an open, human & machine understandable standard. Its main format to interchange data on modern web is XML.
- We have learnt use of JSON in Python dictionaries.
- Its examples are – MongoDB, Couch DB DocumentDB etc.
data:image/s3,"s3://crabby-images/b5aab/b5aabd81e6dd8d0e3c67e8c3d1f9be3743df294f" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Column Family Store Database
- These are known as column store or column family databases and these are column oriented models.
- Column family is a storage mechanism which can –
- Have multiple rows.
- Each row can have multiple columns.
- In this, there is a row key under which there can be multiple columns as shown in the figure.
- Its examples are- Hbase, Cassandra, HyperTable etc.
data:image/s3,"s3://crabby-images/d5c94/d5c9464ab58b481e9590657846a77792ea9a65bb" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Graph Database
- It uses graphical model to store data.
- Here, nodes are used to show object whereas edges are used to show relation between those nodes.
- Its examples are- Neo4j, Blazegraph, Titan etc.
data:image/s3,"s3://crabby-images/132b9/132b9e967582d29208222a3cd6b734e119272812" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
data:image/s3,"s3://crabby-images/9b3b7/9b3b7c5eb51d1211350a10fc0a455bf0afa08932" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Advantages and Disadvantages of NoSQL Databases
Advantages:
- Flexible Data Model These are very flexible database which can store any kind of data.
- Evolving Data Model You can change its schema without downing the system.
- Elastic Scalability Huge database can be stored on a very less cost.
- High Performance Time of throughput and latency is very less.
- Open Source It is available free of cost and you can change it as per yor requirement.
Disadvantages:
- Lack of Standardization No standard rules are there for NoSQL database.
- Backup of Database Main problem with NoSQL databases is of backup. MongoDB provides tool for backup but it is also not up to the mark.
- Consistency NoSQL database does not think about consistency. Means here, you can have duplicate data very easily.
Working with MongoDB
- MongoDB is a document-oriented NoSQL database.
- It supports dynamic schemas which shws data in JSON format.
- It is a free open source software which gives scalability and high performance.
MongoDB Terminology
data:image/s3,"s3://crabby-images/8bd12/8bd1287e4be5af3298e20c0a253e7686a8c806af" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Installing MongoDB
Copy the following link and paste in browser.
data:image/s3,"s3://crabby-images/991d9/991d9a20e4da19fb0db571d21532c6997cb38dfe" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Installation of MongoDB
- Install MongoDB by opeing MSI file.
- After installation, check the availability of mongodb.exe file and mongo.exe file using following path-
- C:\Program Files\MongoDB\Server\4.0\bin
- After this, create a data folder on c:\ and db folder under data folder i.e. “c:\data\db”.
- Now, run mongodb by using the location C:\Program
- Files\MongoDB\Server\4.0\bin from command prompt.
- Do not close mongodb after run.
- Now, in other command window run mongo using the same path.
Starting MongoDB
data:image/s3,"s3://crabby-images/cbb81/cbb81670acbb75fcde7adc5d66699b057b82613e" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB Data Types
data:image/s3,"s3://crabby-images/10448/10448c249fac06e2cf3bd4c11d3666e5684f58eb" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB – Basic commands
- Creation of Database →
It is not required to create seperate database in MongoDB. As soon as you insert first information n database, database automaticaly created. - Displaying Current Database→
>show dbs it shows database
>show collections it shows collections of current database - Using Database→
data:image/s3,"s3://crabby-images/588f9/588f9901245a91af9a259e658ad21bf279571179" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
- >use mydb
- CRUD operations →
The operations are as under –
data:image/s3,"s3://crabby-images/1c53c/1c53c20175f40a5cc430917ef7b571800c99293c" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB – Basic commands
- Creation of databse using Save operation →
It is not required to create seperate database in MongoDB. As soon as you insert first information n database, database automaticaly created. - You can input data in collection by save or insert commanddb.< collection-name>.save({<document details>})
- We can use show collections command to confirm creation of collection.
- >USE <DatabaseName> can also be used to create database
- Following example shows creation of school database and input of 1 collection.
data:image/s3,"s3://crabby-images/3ab45/3ab4590dd21445e1d0e5a95fc260019261fce4a8" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB – Basic commands
- Creation of databse using Save operation→
- We can insert multiple document like —
data:image/s3,"s3://crabby-images/9b5a0/9b5a0d4ab3d2337d32f306b844d9ffe9b2c2679b" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
- When you insert a document, mongoDB adds a field itself “_id” it sets its value in increasing order. This process is not visible to us. If we desire, we can give value of “_id” at the time of insertion.
- If you insert a document using Save or insert and name is not received from given database or collection then mongoDB creates a new database for it.
MongoDB -Basic commands
- Creation of database from Insert operation→
- You can insert data in collection using insert commanddb.< collection-name>.insert({<document details>})
- We can use show collections command to confirm creation of collection.
- Following example shows creation of school database and input of 1 collection.
data:image/s3,"s3://crabby-images/a3468/a346834f0f231e4192c4e543e4d7ce52d5beef34" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
- We can insert multiple document like
- >db.teachers.insertMany([{name:’Ratan’},{name:’Krishna’,age:45}])
MongoDB -Basic commands
- Document can also be inserted by object creation.
data:image/s3,"s3://crabby-images/8d990/8d9906aaa946d6d6a9b8cce2f2ed1b81e22f3d69" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
- An object can have a field which is an object itself.
data:image/s3,"s3://crabby-images/9c5b0/9c5b0fca1ec2aa1225174d14fa6b4d47f8bdcbf5" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic commands
An Object can have arrays too. For ex –
Name: Himanshu
Class:11
Section: A
Subjects: English, Hindi, Maths, Physics, Chemistry
Here subject is an array
data:image/s3,"s3://crabby-images/808b3/808b31128b71e91c3052041736a98c68c21c159d" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic commands
Read Operation:
Read operation is used access documents from collection of database.
Syntax is-
>db.<collection-name>.find() will show all documents of collection.
>db.<collection-name>.findOne() will show only one record.
>db.<collection-name>.findOne({<key>:<value>}) it will work like search criteria.
data:image/s3,"s3://crabby-images/a5682/a5682cb0dd87f3d3c6059d2b97358baeab4de740" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic commands
•Read Operation:
data:image/s3,"s3://crabby-images/cc710/cc7108104b7a42e60f3aff99abe36bea9a0eb5d7" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic commands
•Read Operation:
data:image/s3,"s3://crabby-images/7001b/7001bb734d282137b52c157e1e58efbe80ca3560" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic Operators
•Comparison Operator:
Like other databases, mongoDB also provides operators so that we can perform delete, read or update operations.
data:image/s3,"s3://crabby-images/50b87/50b877f6e9639c3d02b191c6efaac59d961696c6" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB-Basic Operators
•Comparision Operator:
Conditional base or range is to be given as-
{field:{$gte:<lower value>, $lte:<upper value>}}
data:image/s3,"s3://crabby-images/b0a98/b0a98163192fa74db1db2f9e0e8f523e53b0a59d" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB -Basic Operators
•Condition based on List/Array
{ field :{ $in : [ val1,val2, . . . . . ] } }
{ field :{ $nin : [ val1,val2, . . . . . ] } }
data:image/s3,"s3://crabby-images/d4c60/d4c60dc71b368046a324c978b3cec51f43ef6174" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
data:image/s3,"s3://crabby-images/ac9c0/ac9c0134a74a1e66fcc9050b048ebc819c2a8b71" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
MongoDB-Basic Operators
•Logical Query Operators
{ field :{ $not :{<op-Exp>}} }
{ field :{ $and :[{<op-Exp>}, {<op-Exp>},..]} }
{ field :{ $or :[{<op-Exp>}, {<op-Exp>},..]} }
data:image/s3,"s3://crabby-images/d247d/d247dc2ae8ae21e96a71f0f8426b6affbfb2b8d8" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
data:image/s3,"s3://crabby-images/57bc9/57bc908e2269dc95ea6a1efc880f2c9139e5ad11" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Update Operation:
Update operation can be used in two ways-
>update/updateOne or >updateMany ($set operator is used with it)
data:image/s3,"s3://crabby-images/cce92/cce92b6ef164e29d5fd9babb4d9e42490eeb62c7" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
Delete Operation:
Delete operation can be used in two ways-
>deleteOne or >deleteMany
>db.<CollectionName>.deleteOne({<filter Exp>}) it will delete only one record even on multiple matching.
>db.<CollectionName>.deleteMany({<filter Exp>}) it will delete multiple records on multiple matching.
data:image/s3,"s3://crabby-images/6ddb0/6ddb084bbff0d254c42c38882c4ad3a0f5301f4a" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"
data:image/s3,"s3://crabby-images/897a6/897a6ead92f3528565fc14e6d408f5b1051d7d9d" alt="Notes Chapter 20 Basics of NoSQL Databases MongoDB"