2. MONGO DB
MongoDB is a cross-platform, document oriented
database that provides, high performance, high
availability and easy scalability.
MongoDB works on concept of collection and document.
3. MONGO DB
Developed by 10gen
Founded in 2007
A document-oriented, NoSQL database
Hash-based, schema-less database
No Data Definition Language
In practice, this means it can store hashes with any keys
and values.
Keys are a basic data type but in reality stored as strings
4. Contd,
Application tracks the schema and mapping
Based on JSON – B, B stands for Binary
Written in C++
Supports APIs (drivers) in many computer languages,
JavaScript, Python, Ruby, Perl, Java, Scala, C#, C++,
Haskell, Erlang.
6. Functionality of MongoDB
Dynamic schema
No DDL
Document-based database
Secondary indexes
Query language via an API
Atomic writes and fully-consistent reads
Master-slave replication with automated failover (replica
sets)
7. MongoDB: CAP approach
Focus on Consistency and
Partition tolerance
Consistency:
All replicas contain the
same version of data
Availability
System remains operational
on failing nodes
Partition tolarence
Multiple entry points
System remains operational
on system split
CAP Theorem:
satisfying all three at the
same time is impossible
8. Document Store
RDBMS MongoDB
Database Database
Table, View Collection
Row Document
Column Field
Index Index
Join Embedded Document
Foreign Key Reference
9. Features
Document-Oriented storege
Open source
Full Index Support
Replication & High Availability
Auto-Sharding
Querying
Fast In-Place Updates
Map/Reduce functionality.
9
10. Contd,
Easy to install and use
Detailed documentation
Various APIs
Community
10
11. Advantages of MongoDB over RDBMS
Schema less: MongoDB is a document database in
which one collection holds different documents.
Number of fields, content and size of the
document can differ from one document to
another.
Structure of a single object is clear.
No complex joins.
Deep query-ability. MongoDB supports dynamic
queries on documents using a document-based
query language that's nearly as powerful as SQL.
12. Contd,
Ease of scale-out: MongoDB is easy to scale.
Conversion/mapping of application objects to database
objects not needed.
Uses internal memory for storing the working set,
enabling faster access of data.
13. MySQL Vs MongoDB
START TRANSACTION;
INSERT INTO contacts VALUES
(NULL, ‘joeblow’);
INSERT INTO contact_emails VALUES
( NULL, ”joe@blow.com”,
LAST_INSERT_ID() ),
( NULL, “joseph@blow.com”,
LAST_INSERT_ID() );
COMMIT;
MongoDB
db.contacts.save( {
userName: “joeblow”,
emailAddresses: [
“joe@blow.com”,
“joseph@blow.com” ] } );
MySQL
16. Create Database
The use Command,
MongoDB use DATABASE_NAME is used to create
database. The command will create a new database if it
doesn't exist, otherwise it will return the existing database.
Syntax
use DATABASE_NAME
17. Contd,
To check the currently selected database, use the
command db.
Syntax
>db
To check all database lists use the command
Syntax
>show dbs
In MongoDB default database is test. If you didn't create
any database, then collections will be stored in test
database.
18. Drop Database
MongoDB dropDatabase() command is used to
drop a existing database.
Syntax
db.dropDatabase()
This will delete the selected database.
If any database is not selected, then it will delete default
'test' database.
19.
20. Create Collection
MongoDB createCollection is used to create
collection.
Syntax
db.createCollection(name, options)
name is name of collection to be created.
Options is a document and is used to specify
configuration of collection like memory size and indexing.
To check the created collection by using the command show
collections.
23. Drop a Collection
MongoDB's collection.drop() is used to drop a collection
from the database.
Syntax
db.COLLECTION_NAME.drop()
24.
25. Disadvantages
Usage of memory- server will need lot of RAM
Less flexibility with querying (eg. No joins)
No Support for transactions.
Concurrency issues
Create
The field name _id is reserved for use as a primary key; its value must be unique in the collection, is immutable, and may be of any type other than an array.
The field names cannot start with the $ character.
The field names cannot contain the . character.
Create with save
If the <document> argument does not contain the _id field or contains an _id field with a value not in the collection, the save() method performs an insert of the document.
Otherwise, the save() method performs an update.
sds