An Introduction to NoSQL
Thameera Senanayaka
Allion Technologies
- SQL Server
- MySQL
- PostgreSQL
- Oracle
- SQLite
data:image/s3,"s3://crabby-images/06e9f/06e9f9baec6f4f76a54973de20ecb89bdd2e7cc2" alt=""
Databases we use
data:image/s3,"s3://crabby-images/a5e2e/a5e2ebb69b780144236ced91d27e5a31aa136872" alt=""
data:image/s3,"s3://crabby-images/7f519/7f5194a4f781f7d0c18e0510be5710da7a81c63a" alt=""
data:image/s3,"s3://crabby-images/015fb/015fbf560910c2642c2696dc1f46ffdd941e64ca" alt=""
data:image/s3,"s3://crabby-images/7fd18/7fd18a491a0ded540c6de22f2e279e8a74cab862" alt=""
Relational Databases
data:image/s3,"s3://crabby-images/a53c7/a53c77750280761405b9ca2e67f15544c0d81735" alt=""
data:image/s3,"s3://crabby-images/29f21/29f2180e20298840b41dd4dd1de95cb30f05ec9e" alt=""
Relational Databases
- Tables
- Schemas & Normalization
- SQL to query data
data:image/s3,"s3://crabby-images/efe59/efe59edbb129b53033b44e5b7eba2ad6acc59a8d" alt=""
data:image/s3,"s3://crabby-images/5ae59/5ae594fe5b73c6a47ca5b3fda698fc3937b64460" alt=""
data:image/s3,"s3://crabby-images/31596/31596856c294f4eedc88611782139ffdfa41ac92" alt=""
What is NoSQL?
- Any database that is not a relational database
- Schema-less
- Running well on clusters
NoSQL !=
data:image/s3,"s3://crabby-images/4fea5/4fea5c1b2a2a28b8ba841a0fe1e7fc7bd030b180" alt=""
NoSQL ==
data:image/s3,"s3://crabby-images/be235/be235c13b786f9fbb27057c90986b5cbf25db039" alt=""
data:image/s3,"s3://crabby-images/1cde2/1cde20d6e5eb51f42ad070118df3e3f1af87b6bb" alt=""
{
_id: xxxxx,
article_id: yyyy,
time: yymmdd,
text: abcde
}
Use Case - Comments in a blog
Use Case - Comments in a blog
{
_id: xxxxx,
article_id: yyyy,
time: yymmdd,
text: abcde,
author: {
id: xxx,
name: 'user'
}
}
Use Case - Comments in a blog
{
_id: xxxxx,
article_id: yyyy,
time: yymmdd,
text: abcde,
author: {
id: xxx,
name: 'user'
},
replies: [
{ ... },
{ ... }
]
}
Use Case - Comments in a blog
{
title: 'some title',
post: 'post',
date: yymmdd,
comments: [
{
_id: xxxxx,
time: yymmdd,
text: abcde,
author: {
id: xxx,
name: 'user'
},
replies: [
{ ... },
{ ... }
]
},
{
...
}
]
}
Types of NoSQL databases
1. Document Store
data:image/s3,"s3://crabby-images/d8e8e/d8e8e429638b82b19a8bd10fe684306e0928d0b6" alt=""
data:image/s3,"s3://crabby-images/0bce6/0bce62b49c652ef2602096d392db6a29fc8072ed" alt=""
data:image/s3,"s3://crabby-images/dd631/dd631540922143c5bf5d62645619cde2eebf7d36" alt=""
Types of NoSQL databases
2. BigTable
data:image/s3,"s3://crabby-images/7f7f4/7f7f45fdc2e96e67d98789c9e86de0d824156293" alt=""
data:image/s3,"s3://crabby-images/80a77/80a776e3106a9938538057018ffd9506f90840c2" alt=""
data:image/s3,"s3://crabby-images/95654/956548730ad5027f7830caa58c2f16b4546d7960" alt=""
Types of NoSQL databases
3. Key-value store
data:image/s3,"s3://crabby-images/1475e/1475ed6ab51ae5e1f8f65e8979450e04e81ef44b" alt=""
data:image/s3,"s3://crabby-images/ebf94/ebf941fb69f77bec57f8d4a335fdcfeecc8bf80f" alt=""
data:image/s3,"s3://crabby-images/53702/537026e1332fd1797862e5e7327bbaa3e46ebb84" alt=""
Types of NoSQL databases
4. Graph
data:image/s3,"s3://crabby-images/89f54/89f547d5c14050844a0a8b311e30e308c1204d12" alt=""
data:image/s3,"s3://crabby-images/bd4ef/bd4efa6dfe8dfa9b34671d2ea8f36ba596a6e399" alt=""
SQL | NoSQL |
---|---|
Rows | Documents |
Tables | Columns |
Requires a schema | Schema-less |
JOINs | No JOINs (data is denormalized) |
Transactional guarantees | No guarantees for multiple documents |
Can be scaled (with some effort) | Excellent performance & scalability |
SQL querying | JSON data object querying |
Why NoSQL?
- Big data
- Real time analytics
- IoT
- Rapid development
data:image/s3,"s3://crabby-images/48b4f/48b4fe5ac250f8e3de4f196bc1678d975550ea53" alt=""
data:image/s3,"s3://crabby-images/d8a6b/d8a6bf6fc9eacec4e5eb55b4d2c6eb1cad073ee1" alt=""
data:image/s3,"s3://crabby-images/4e4a4/4e4a4c9527372683ff5dca6bb05e2f0dfd3f72c1" alt=""
data:image/s3,"s3://crabby-images/08cdd/08cdd0606f21e3b640f679c5d7d4d05b8ebd1ff5" alt=""
Final words
- None is better than the other
- Right tool for right job
- Don't think everything is a nail for your hammer
data:image/s3,"s3://crabby-images/7c662/7c662713f49aea2cd81b9f6864bb292b24208945" alt=""
Thank you!
Introduction to NoSQL
By Thameera
Introduction to NoSQL
- 1,402