SlideShare a Scribd company logo
Scala with MongoDB

Abdhesh Kumar
Email: abdhesh@knoldus.com
Twitter:@abdheshkumar90
Agenda
1. What is MongoDB?
2. Why we use MongoDB?
3. What are the MongoDB Terminologies?
4. How to Install and Use MonogDB?
5. What are the Operators of MongoDB?
6. What is Casbah?
7. What is Salat?
What is MongoDB?
➢ MongoDB is a document-oriented database management
system designed for performance, horizontal scalability, high
availability,open source NoSQL database(Schemaless or
Non-relational) ,And advanced queryability.
➢ MongoDB is a document-based database system, and as a
result, all records, or data, in MongoDB are documents.
Why we use MongoDB?
Document Oriented
➢ Documents (objects) map nicely to programming language data
types.
➢ Dynamically-typed (schemaless) for easy schema evolution.
➢ No joins and no transactions for high performance and easy
scalability
High Performance
➢ No joins and no transactions makes reads and writes fast
➢ Indexes can include keys from embedded documents and
arrays.
➢ Optional asynchronous writes
.
High Availability
➢Replicated servers with automatic master failover.
Easy Scalability
➢ Automatic sharding distributes collection data across machines.
➢Reads and writes are distributed over shards
Flexibility
➢MongoDB stores data in JSON documents (which we serialize
to BSON).
Indexing
➢ MongoDB supports generic secondary indexes, allowing a
variety of fast queries,and provides unique, compound, and
geospatial indexing capabilities as well.
Fixed-size collections
➢ Capped collections are fixed in size and are useful for certain
types of data, such as logs.
➢ Real time aggregation
➢ Rich query capabilities
➢ Geospatial features
➢ Flexible schema
MongoDB Terminologies
Sql Terms/Concepts

MongoDB Terms/Concepts

database

database

table

collection

index

index

row

Document or *BSON document

column

Field or BSON field

join

*Embedding and linking

Primary key

_id

Group by

aggregation
MongoDB Terms/Concepts
Documents:
➢ The concept of a document: an ordered set of keys with
associated values.
➢ documents are represented as objects:
{"greeting" : "Hello, world!"}
Collections:
➢ A collection is a group of documents.
Embedding:
➢ “Embedding is the nesting of objects and arrays inside a
BSON document”
Linking:
➢ “Links are references between documents”
Aggregation:
➢ The MongoDB aggregation framework provides a means to
calculate aggregated values without having to use map-reduce.
➢ If you’re familiar with SQL, the aggregation framework
provides similar functionality to GROUP BY and related SQL
operators as well as simple forms of “self joins.” Additionally,
the aggregation framework provides projection capabilities to
reshape the returned data.
What is JSON?
➢ JSON (JavaScript Object Notation) is a lightweight
data-interchange format.
➢ JSON is built on two structures:
1. A collection of name/value pairs. ex.object, record, struct,
dictionary, hash table, keyed list, or associative array
2. An ordered list of values. ex. array, vector, list, or sequence
{
"_id" : 1,
"name" : { "first" : "Rohan", "last" : "Singh" },
"contributes" : [ "TypeSafe", "Knoldus" ],
"awards" : [
{
"award" : "Play Framework Expert",
"year" : 2012,
"by" : "TypeSafe"
},
{ "award" : "Scala Expert",
"year" : 2013,
"by" : "Knoldus"
}
]
}
What is BSON?
➢ BSON is a binary-encoded serialization of JSON-like
document.
➢ BSON supports the embedding of documents and arrays
within other documents and arrays.
➢ MongoDB uses BSON as the data storage and network
transfer format for “documets”.
Install MongoDB
$ wget
http://downloads.mongodb.org/osx/mongodb-osx-x86_64-2.0.6.tgz
$ tar -zxvf mongodb-osx-x86_64-2.0.6.tgz
$ sudo mkdir -p /data/db
$ sudo chown `id -u` /data/db
Starting MonDB and Mongo Shell
➢ $ ./bin/mongod
➢ $ mongo
MongoDB shell version: 2.4.1
connecting to: test
>
MongoDB Operators
Query Selectors:
➢ Comparison
$all, $gt, $gte, $in, $lt, $lte, $ne, $nin
➢ Logical
$and, $or, $nor, $not
➢ Element
$exists, $mod, $type
➢ JavaScript
$regix, $where
➢ Array
$elemMatch,$size

Update
➢ Fields
$inc, $set, $unset
➢ Array
$, $addToSet, $pop, $pullAll, $pull, $pushAll, $push

Projection
$, $elemMatch, $slice
What is the Casbah?
➢ Casbah is a Scala toolkit for MongoDB—We use the term “toolkit” rather
than “driver”, as Casbah integrates a layer on top of the official
mongo-java-driver for better integration with Scala.
Installing & Setting up Casbah
*You should have MongoDB setup and running on your machine.
Add casbah dependencies to buid.sbt

resolvers += "Scala-tools" at
"https://oss.sonatype.org/content/groups/scala-tools"
resolvers += "Sonatype Snapshot" at
"https://oss.sonatype.org/content/repositories/releases"
libraryDependencies ++= Seq(
"org.mongodb" % "casbah_2.10" % "2.5.1"
)
Use Casbah with Scala
➢ Import the Driver
import com.mongodb.casbah.Imports._

➢ Connecting to MongoDB
Connect to default - localhost, 27017
val mongoConnection = MongoConnection()
connect to "mongodb01" host, default port
val mongoConnection = MongoConnection("mongodb01")
connect to "mongodb02" host, port 42017
val mongoConnection = MongoConnection("mongodb02", 42017)
val mongoDB = mongoConnection("casbah_test")
Connect casbah_test database with test_data collecion by chaining
val mongoColl = mongoConnection("casbah_test")("test_data")

Working with Collections
What is Salat?
➢ Salat is a bi-directional Scala case class serialization library.
➢ Salat provides fast, reliable bi-directional serialization between
Scala case classes and MongoDB's DBObject format.
➢ case classes can be used directly for storing document by
simply declaring a DAO and with the help of some annotations
Salat DAO
SalatDAOmakes it simple to start working with your case class objects.
Use it as is or as the basis for your own DAO implementation.
By extending SalatDAO, you can do the following out of box:
➢ insert and get back an Option with the id
➢ findOne and get back an Option
➢ typed to your case class
➢ find and get back a Mongo cursor typed to your class
➢ iterate, limit, skip and sort
➢ update with a query and a case class
➢ save and remove case classes
➢ Projections
➢ built-in support for child collections
What Scala types can Salat handle?
➢ case classes
➢ embedded case classes
➢ embedded case classes typed to a trait or abstract superclass annotated
with @Salat
➢ Scala enums
➢ Options
➢ Collections

Collections
➢ Maps are represented as DBObject ; all other collections turn into DBList .
Salat collection support
Salat 0.0.8-SNAPSHOT and above support the following mutable and
immutable collections:
➢ Map
➢ Lists and linked lists
➢ Seqs and indexed seqs
➢ Set
➢ Buffer
➢ Vector
Salat Unsupported types
Salat can't support any of these types right now:
➢ Nested inner classes
➢ A class typed at the top-level to a trait or an abstract superclass

Salat can't support these types because the mongo-java-driver doesn't support
Them:
➢ Any type of Map whose key is not a String
➢ any type of map whose key is a String containing . or $
Salat Supports Annotations
Salat offers the following annotations to customize serialization
behavior:
➢ @Salat to support polymorphic instances of a trait or abstract
superclass
➢ @Key to change the name of a field
➢ @Persist to serialize a value outside the case class constructor
➢ @Ignore to ignore a field in the case class constructor
➢ @EnumAs to customize the behavior of a particular enum
Salat Grater
Grater
Salat as the notion of Grater that is responsible to the de/serialization
of a case class.
This through two simple functions, let have a Grater for the type T:
➢ asDBObject(t:T) : returns a MongoDB representation of t
➢ asObject(dbo:DBObject)[T] : returns a T instance based on the
provided
Mo ngoDB content
Installing & Setting up Salat
Add salat dependencies to buid.sbt
resolvers += "Novus Release Repository" at "http://repo.novus.com/releases/"
resolvers += "Sonatype OSS Snapshots" at "
https://oss.sonatype.org/content/repositories/snapshots"

libraryDependencies ++= Seq(
"com.novus" %% "salat" % "1.9.2-SNAPSHOT"
)
References
http://docs.mongodb.org/manual/

More Related Content

What's hot

MongoDB 101
MongoDB 101MongoDB 101
MongoDB 101
Abhijeet Vaikar
 
Learn Learn how to build your mobile back-end with MongoDB
Learn Learn how to build your mobile back-end with MongoDBLearn Learn how to build your mobile back-end with MongoDB
Learn Learn how to build your mobile back-end with MongoDB
Marakana Inc.
 
Introduction to JSON & AJAX
Introduction to JSON & AJAXIntroduction to JSON & AJAX
Introduction to JSON & AJAX
Collaboration Technologies
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDBJustin Smestad
 
Mongo db operations_v2
Mongo db operations_v2Mongo db operations_v2
Mongo db operations_v2
Thanabalan Sathneeganandan
 
Web Services with Objective-C
Web Services with Objective-CWeb Services with Objective-C
Web Services with Objective-C
Juio Barros
 
Basics of MongoDB
Basics of MongoDB Basics of MongoDB
Basics of MongoDB
Habilelabs
 
mobile in the cloud with diamonds. improved.
mobile in the cloud with diamonds. improved.mobile in the cloud with diamonds. improved.
mobile in the cloud with diamonds. improved.
Oleg Shanyuk
 
Introduction to Elasticsearch
Introduction to ElasticsearchIntroduction to Elasticsearch
Introduction to Elasticsearch
Sperasoft
 
An Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDBAn Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDB
Lee Theobald
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDB
Mike Dirolf
 
Using Webservice in iOS
Using Webservice  in iOS Using Webservice  in iOS
Using Webservice in iOS
Mahboob Nur
 
Node js crash course session 5
Node js crash course   session 5Node js crash course   session 5
Node js crash course session 5
Abdul Rahman Masri Attal
 
MongoDB
MongoDBMongoDB
Connecting to a REST API in iOS
Connecting to a REST API in iOSConnecting to a REST API in iOS
Connecting to a REST API in iOS
gillygize
 
Ajax xml json
Ajax xml jsonAjax xml json
Ajax xml json
Andrii Siusko
 
OSCON 2012 MongoDB Tutorial
OSCON 2012 MongoDB TutorialOSCON 2012 MongoDB Tutorial
OSCON 2012 MongoDB Tutorial
Steven Francia
 
Apache Any23 - Anything to Triples
Apache Any23 - Anything to TriplesApache Any23 - Anything to Triples
Apache Any23 - Anything to Triples
Michele Mostarda
 
Building your first app with mongo db
Building your first app with mongo dbBuilding your first app with mongo db
Building your first app with mongo db
MongoDB
 
Mongo db
Mongo dbMongo db
Mongo db
Noman Ellahi
 

What's hot (20)

MongoDB 101
MongoDB 101MongoDB 101
MongoDB 101
 
Learn Learn how to build your mobile back-end with MongoDB
Learn Learn how to build your mobile back-end with MongoDBLearn Learn how to build your mobile back-end with MongoDB
Learn Learn how to build your mobile back-end with MongoDB
 
Introduction to JSON & AJAX
Introduction to JSON & AJAXIntroduction to JSON & AJAX
Introduction to JSON & AJAX
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDB
 
Mongo db operations_v2
Mongo db operations_v2Mongo db operations_v2
Mongo db operations_v2
 
Web Services with Objective-C
Web Services with Objective-CWeb Services with Objective-C
Web Services with Objective-C
 
Basics of MongoDB
Basics of MongoDB Basics of MongoDB
Basics of MongoDB
 
mobile in the cloud with diamonds. improved.
mobile in the cloud with diamonds. improved.mobile in the cloud with diamonds. improved.
mobile in the cloud with diamonds. improved.
 
Introduction to Elasticsearch
Introduction to ElasticsearchIntroduction to Elasticsearch
Introduction to Elasticsearch
 
An Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDBAn Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDB
 
Introduction to MongoDB
Introduction to MongoDBIntroduction to MongoDB
Introduction to MongoDB
 
Using Webservice in iOS
Using Webservice  in iOS Using Webservice  in iOS
Using Webservice in iOS
 
Node js crash course session 5
Node js crash course   session 5Node js crash course   session 5
Node js crash course session 5
 
MongoDB
MongoDBMongoDB
MongoDB
 
Connecting to a REST API in iOS
Connecting to a REST API in iOSConnecting to a REST API in iOS
Connecting to a REST API in iOS
 
Ajax xml json
Ajax xml jsonAjax xml json
Ajax xml json
 
OSCON 2012 MongoDB Tutorial
OSCON 2012 MongoDB TutorialOSCON 2012 MongoDB Tutorial
OSCON 2012 MongoDB Tutorial
 
Apache Any23 - Anything to Triples
Apache Any23 - Anything to TriplesApache Any23 - Anything to Triples
Apache Any23 - Anything to Triples
 
Building your first app with mongo db
Building your first app with mongo dbBuilding your first app with mongo db
Building your first app with mongo db
 
Mongo db
Mongo dbMongo db
Mongo db
 

Similar to Scala with mongodb

Mongo Bb - NoSQL tutorial
Mongo Bb - NoSQL tutorialMongo Bb - NoSQL tutorial
Mongo Bb - NoSQL tutorial
Mohan Rathour
 
Big data technology unit 3
Big data technology unit 3Big data technology unit 3
Big data technology unit 3
RojaT4
 
Mongodb - NoSql Database
Mongodb - NoSql DatabaseMongodb - NoSql Database
Mongodb - NoSql Database
Prashant Gupta
 
Rails meets no sql
Rails meets no sqlRails meets no sql
Rails meets no sql
Simon Escobar Benitez
 
Mongo db
Mongo dbMongo db
Mongo db
Gyanendra Yadav
 
NOSQL and MongoDB Database
NOSQL and MongoDB DatabaseNOSQL and MongoDB Database
NOSQL and MongoDB Database
Tariqul islam
 
Introduction to mongodb
Introduction to mongodbIntroduction to mongodb
Introduction to mongodb
Mohammed Ragab
 
Mongo db transcript
Mongo db transcriptMongo db transcript
Mongo db transcript
foliba
 
MongoDB
MongoDBMongoDB
MongoDB
fsbrooke
 
Azure SQL & SQL Server 2016 JSON
Azure SQL & SQL Server 2016 JSONAzure SQL & SQL Server 2016 JSON
Azure SQL & SQL Server 2016 JSON
Davide Mauri
 
Kalp Corporate MongoDB Tutorials
Kalp Corporate MongoDB TutorialsKalp Corporate MongoDB Tutorials
Kalp Corporate MongoDB Tutorials
Kalp Corporate
 
Klevis Mino: MongoDB
Klevis Mino: MongoDBKlevis Mino: MongoDB
Klevis Mino: MongoDB
Carlo Vaccari
 
No sql databases
No sql databasesNo sql databases
No sql databases
Walaa Hamdy Assy
 
Software development - the java perspective
Software development - the java perspectiveSoftware development - the java perspective
Software development - the java perspective
Alin Pandichi
 
Mongo presentation conf
Mongo presentation confMongo presentation conf
Mongo presentation confShridhar Joshi
 
No SQL - MongoDB
No SQL - MongoDBNo SQL - MongoDB
No SQL - MongoDB
Mirza Asif
 
Introduction to Cosmos DB Presentation.pptx
Introduction to Cosmos DB Presentation.pptxIntroduction to Cosmos DB Presentation.pptx
Introduction to Cosmos DB Presentation.pptx
Knoldus Inc.
 
JS App Architecture
JS App ArchitectureJS App Architecture
JS App Architecture
Corey Butler
 
nosql [Autosaved].pptx
nosql [Autosaved].pptxnosql [Autosaved].pptx
nosql [Autosaved].pptx
Indrani Sen
 
MongoDB - An Introduction
MongoDB - An IntroductionMongoDB - An Introduction
MongoDB - An Introduction
sethfloydjr
 

Similar to Scala with mongodb (20)

Mongo Bb - NoSQL tutorial
Mongo Bb - NoSQL tutorialMongo Bb - NoSQL tutorial
Mongo Bb - NoSQL tutorial
 
Big data technology unit 3
Big data technology unit 3Big data technology unit 3
Big data technology unit 3
 
Mongodb - NoSql Database
Mongodb - NoSql DatabaseMongodb - NoSql Database
Mongodb - NoSql Database
 
Rails meets no sql
Rails meets no sqlRails meets no sql
Rails meets no sql
 
Mongo db
Mongo dbMongo db
Mongo db
 
NOSQL and MongoDB Database
NOSQL and MongoDB DatabaseNOSQL and MongoDB Database
NOSQL and MongoDB Database
 
Introduction to mongodb
Introduction to mongodbIntroduction to mongodb
Introduction to mongodb
 
Mongo db transcript
Mongo db transcriptMongo db transcript
Mongo db transcript
 
MongoDB
MongoDBMongoDB
MongoDB
 
Azure SQL & SQL Server 2016 JSON
Azure SQL & SQL Server 2016 JSONAzure SQL & SQL Server 2016 JSON
Azure SQL & SQL Server 2016 JSON
 
Kalp Corporate MongoDB Tutorials
Kalp Corporate MongoDB TutorialsKalp Corporate MongoDB Tutorials
Kalp Corporate MongoDB Tutorials
 
Klevis Mino: MongoDB
Klevis Mino: MongoDBKlevis Mino: MongoDB
Klevis Mino: MongoDB
 
No sql databases
No sql databasesNo sql databases
No sql databases
 
Software development - the java perspective
Software development - the java perspectiveSoftware development - the java perspective
Software development - the java perspective
 
Mongo presentation conf
Mongo presentation confMongo presentation conf
Mongo presentation conf
 
No SQL - MongoDB
No SQL - MongoDBNo SQL - MongoDB
No SQL - MongoDB
 
Introduction to Cosmos DB Presentation.pptx
Introduction to Cosmos DB Presentation.pptxIntroduction to Cosmos DB Presentation.pptx
Introduction to Cosmos DB Presentation.pptx
 
JS App Architecture
JS App ArchitectureJS App Architecture
JS App Architecture
 
nosql [Autosaved].pptx
nosql [Autosaved].pptxnosql [Autosaved].pptx
nosql [Autosaved].pptx
 
MongoDB - An Introduction
MongoDB - An IntroductionMongoDB - An Introduction
MongoDB - An Introduction
 

More from Knoldus Inc.

Using InfluxDB for real-time monitoring in Jmeter
Using InfluxDB for real-time monitoring in JmeterUsing InfluxDB for real-time monitoring in Jmeter
Using InfluxDB for real-time monitoring in Jmeter
Knoldus Inc.
 
Intoduction to KubeVela Presentation (DevOps)
Intoduction to KubeVela Presentation (DevOps)Intoduction to KubeVela Presentation (DevOps)
Intoduction to KubeVela Presentation (DevOps)
Knoldus Inc.
 
Stakeholder Management (Project Management) Presentation
Stakeholder Management (Project Management) PresentationStakeholder Management (Project Management) Presentation
Stakeholder Management (Project Management) Presentation
Knoldus Inc.
 
Introduction To Kaniko (DevOps) Presentation
Introduction To Kaniko (DevOps) PresentationIntroduction To Kaniko (DevOps) Presentation
Introduction To Kaniko (DevOps) Presentation
Knoldus Inc.
 
Efficient Test Environments with Infrastructure as Code (IaC)
Efficient Test Environments with Infrastructure as Code (IaC)Efficient Test Environments with Infrastructure as Code (IaC)
Efficient Test Environments with Infrastructure as Code (IaC)
Knoldus Inc.
 
Exploring Terramate DevOps (Presentation)
Exploring Terramate DevOps (Presentation)Exploring Terramate DevOps (Presentation)
Exploring Terramate DevOps (Presentation)
Knoldus Inc.
 
Clean Code in Test Automation Differentiating Between the Good and the Bad
Clean Code in Test Automation  Differentiating Between the Good and the BadClean Code in Test Automation  Differentiating Between the Good and the Bad
Clean Code in Test Automation Differentiating Between the Good and the Bad
Knoldus Inc.
 
Integrating AI Capabilities in Test Automation
Integrating AI Capabilities in Test AutomationIntegrating AI Capabilities in Test Automation
Integrating AI Capabilities in Test Automation
Knoldus Inc.
 
State Management with NGXS in Angular.pptx
State Management with NGXS in Angular.pptxState Management with NGXS in Angular.pptx
State Management with NGXS in Angular.pptx
Knoldus Inc.
 
Authentication in Svelte using cookies.pptx
Authentication in Svelte using cookies.pptxAuthentication in Svelte using cookies.pptx
Authentication in Svelte using cookies.pptx
Knoldus Inc.
 
OAuth2 Implementation Presentation (Java)
OAuth2 Implementation Presentation (Java)OAuth2 Implementation Presentation (Java)
OAuth2 Implementation Presentation (Java)
Knoldus Inc.
 
Supply chain security with Kubeclarity.pptx
Supply chain security with Kubeclarity.pptxSupply chain security with Kubeclarity.pptx
Supply chain security with Kubeclarity.pptx
Knoldus Inc.
 
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML ParsingMastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
Knoldus Inc.
 
Akka gRPC Essentials A Hands-On Introduction
Akka gRPC Essentials A Hands-On IntroductionAkka gRPC Essentials A Hands-On Introduction
Akka gRPC Essentials A Hands-On Introduction
Knoldus Inc.
 
Entity Core with Core Microservices.pptx
Entity Core with Core Microservices.pptxEntity Core with Core Microservices.pptx
Entity Core with Core Microservices.pptx
Knoldus Inc.
 
Introduction to Redis and its features.pptx
Introduction to Redis and its features.pptxIntroduction to Redis and its features.pptx
Introduction to Redis and its features.pptx
Knoldus Inc.
 
GraphQL with .NET Core Microservices.pdf
GraphQL with .NET Core Microservices.pdfGraphQL with .NET Core Microservices.pdf
GraphQL with .NET Core Microservices.pdf
Knoldus Inc.
 
NuGet Packages Presentation (DoT NeT).pptx
NuGet Packages Presentation (DoT NeT).pptxNuGet Packages Presentation (DoT NeT).pptx
NuGet Packages Presentation (DoT NeT).pptx
Knoldus Inc.
 
Data Quality in Test Automation Navigating the Path to Reliable Testing
Data Quality in Test Automation Navigating the Path to Reliable TestingData Quality in Test Automation Navigating the Path to Reliable Testing
Data Quality in Test Automation Navigating the Path to Reliable Testing
Knoldus Inc.
 
K8sGPTThe AI​ way to diagnose Kubernetes
K8sGPTThe AI​ way to diagnose KubernetesK8sGPTThe AI​ way to diagnose Kubernetes
K8sGPTThe AI​ way to diagnose Kubernetes
Knoldus Inc.
 

More from Knoldus Inc. (20)

Using InfluxDB for real-time monitoring in Jmeter
Using InfluxDB for real-time monitoring in JmeterUsing InfluxDB for real-time monitoring in Jmeter
Using InfluxDB for real-time monitoring in Jmeter
 
Intoduction to KubeVela Presentation (DevOps)
Intoduction to KubeVela Presentation (DevOps)Intoduction to KubeVela Presentation (DevOps)
Intoduction to KubeVela Presentation (DevOps)
 
Stakeholder Management (Project Management) Presentation
Stakeholder Management (Project Management) PresentationStakeholder Management (Project Management) Presentation
Stakeholder Management (Project Management) Presentation
 
Introduction To Kaniko (DevOps) Presentation
Introduction To Kaniko (DevOps) PresentationIntroduction To Kaniko (DevOps) Presentation
Introduction To Kaniko (DevOps) Presentation
 
Efficient Test Environments with Infrastructure as Code (IaC)
Efficient Test Environments with Infrastructure as Code (IaC)Efficient Test Environments with Infrastructure as Code (IaC)
Efficient Test Environments with Infrastructure as Code (IaC)
 
Exploring Terramate DevOps (Presentation)
Exploring Terramate DevOps (Presentation)Exploring Terramate DevOps (Presentation)
Exploring Terramate DevOps (Presentation)
 
Clean Code in Test Automation Differentiating Between the Good and the Bad
Clean Code in Test Automation  Differentiating Between the Good and the BadClean Code in Test Automation  Differentiating Between the Good and the Bad
Clean Code in Test Automation Differentiating Between the Good and the Bad
 
Integrating AI Capabilities in Test Automation
Integrating AI Capabilities in Test AutomationIntegrating AI Capabilities in Test Automation
Integrating AI Capabilities in Test Automation
 
State Management with NGXS in Angular.pptx
State Management with NGXS in Angular.pptxState Management with NGXS in Angular.pptx
State Management with NGXS in Angular.pptx
 
Authentication in Svelte using cookies.pptx
Authentication in Svelte using cookies.pptxAuthentication in Svelte using cookies.pptx
Authentication in Svelte using cookies.pptx
 
OAuth2 Implementation Presentation (Java)
OAuth2 Implementation Presentation (Java)OAuth2 Implementation Presentation (Java)
OAuth2 Implementation Presentation (Java)
 
Supply chain security with Kubeclarity.pptx
Supply chain security with Kubeclarity.pptxSupply chain security with Kubeclarity.pptx
Supply chain security with Kubeclarity.pptx
 
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML ParsingMastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
Mastering Web Scraping with JSoup Unlocking the Secrets of HTML Parsing
 
Akka gRPC Essentials A Hands-On Introduction
Akka gRPC Essentials A Hands-On IntroductionAkka gRPC Essentials A Hands-On Introduction
Akka gRPC Essentials A Hands-On Introduction
 
Entity Core with Core Microservices.pptx
Entity Core with Core Microservices.pptxEntity Core with Core Microservices.pptx
Entity Core with Core Microservices.pptx
 
Introduction to Redis and its features.pptx
Introduction to Redis and its features.pptxIntroduction to Redis and its features.pptx
Introduction to Redis and its features.pptx
 
GraphQL with .NET Core Microservices.pdf
GraphQL with .NET Core Microservices.pdfGraphQL with .NET Core Microservices.pdf
GraphQL with .NET Core Microservices.pdf
 
NuGet Packages Presentation (DoT NeT).pptx
NuGet Packages Presentation (DoT NeT).pptxNuGet Packages Presentation (DoT NeT).pptx
NuGet Packages Presentation (DoT NeT).pptx
 
Data Quality in Test Automation Navigating the Path to Reliable Testing
Data Quality in Test Automation Navigating the Path to Reliable TestingData Quality in Test Automation Navigating the Path to Reliable Testing
Data Quality in Test Automation Navigating the Path to Reliable Testing
 
K8sGPTThe AI​ way to diagnose Kubernetes
K8sGPTThe AI​ way to diagnose KubernetesK8sGPTThe AI​ way to diagnose Kubernetes
K8sGPTThe AI​ way to diagnose Kubernetes
 

Recently uploaded

To Graph or Not to Graph Knowledge Graph Architectures and LLMs
To Graph or Not to Graph Knowledge Graph Architectures and LLMsTo Graph or Not to Graph Knowledge Graph Architectures and LLMs
To Graph or Not to Graph Knowledge Graph Architectures and LLMs
Paul Groth
 
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
Sri Ambati
 
PHP Frameworks: I want to break free (IPC Berlin 2024)
PHP Frameworks: I want to break free (IPC Berlin 2024)PHP Frameworks: I want to break free (IPC Berlin 2024)
PHP Frameworks: I want to break free (IPC Berlin 2024)
Ralf Eggert
 
How world-class product teams are winning in the AI era by CEO and Founder, P...
How world-class product teams are winning in the AI era by CEO and Founder, P...How world-class product teams are winning in the AI era by CEO and Founder, P...
How world-class product teams are winning in the AI era by CEO and Founder, P...
Product School
 
Essentials of Automations: Optimizing FME Workflows with Parameters
Essentials of Automations: Optimizing FME Workflows with ParametersEssentials of Automations: Optimizing FME Workflows with Parameters
Essentials of Automations: Optimizing FME Workflows with Parameters
Safe Software
 
Search and Society: Reimagining Information Access for Radical Futures
Search and Society: Reimagining Information Access for Radical FuturesSearch and Society: Reimagining Information Access for Radical Futures
Search and Society: Reimagining Information Access for Radical Futures
Bhaskar Mitra
 
JMeter webinar - integration with InfluxDB and Grafana
JMeter webinar - integration with InfluxDB and GrafanaJMeter webinar - integration with InfluxDB and Grafana
JMeter webinar - integration with InfluxDB and Grafana
RTTS
 
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
Jeffrey Haguewood
 
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
UiPathCommunity
 
ODC, Data Fabric and Architecture User Group
ODC, Data Fabric and Architecture User GroupODC, Data Fabric and Architecture User Group
ODC, Data Fabric and Architecture User Group
CatarinaPereira64715
 
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
Product School
 
GraphRAG is All You need? LLM & Knowledge Graph
GraphRAG is All You need? LLM & Knowledge GraphGraphRAG is All You need? LLM & Knowledge Graph
GraphRAG is All You need? LLM & Knowledge Graph
Guy Korland
 
Mission to Decommission: Importance of Decommissioning Products to Increase E...
Mission to Decommission: Importance of Decommissioning Products to Increase E...Mission to Decommission: Importance of Decommissioning Products to Increase E...
Mission to Decommission: Importance of Decommissioning Products to Increase E...
Product School
 
State of ICS and IoT Cyber Threat Landscape Report 2024 preview
State of ICS and IoT Cyber Threat Landscape Report 2024 previewState of ICS and IoT Cyber Threat Landscape Report 2024 preview
State of ICS and IoT Cyber Threat Landscape Report 2024 preview
Prayukth K V
 
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptxIOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
Abida Shariff
 
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
Thierry Lestable
 
The Future of Platform Engineering
The Future of Platform EngineeringThe Future of Platform Engineering
The Future of Platform Engineering
Jemma Hussein Allen
 
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
Ramesh Iyer
 
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
Product School
 
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
Product School
 

Recently uploaded (20)

To Graph or Not to Graph Knowledge Graph Architectures and LLMs
To Graph or Not to Graph Knowledge Graph Architectures and LLMsTo Graph or Not to Graph Knowledge Graph Architectures and LLMs
To Graph or Not to Graph Knowledge Graph Architectures and LLMs
 
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
GenAISummit 2024 May 28 Sri Ambati Keynote: AGI Belongs to The Community in O...
 
PHP Frameworks: I want to break free (IPC Berlin 2024)
PHP Frameworks: I want to break free (IPC Berlin 2024)PHP Frameworks: I want to break free (IPC Berlin 2024)
PHP Frameworks: I want to break free (IPC Berlin 2024)
 
How world-class product teams are winning in the AI era by CEO and Founder, P...
How world-class product teams are winning in the AI era by CEO and Founder, P...How world-class product teams are winning in the AI era by CEO and Founder, P...
How world-class product teams are winning in the AI era by CEO and Founder, P...
 
Essentials of Automations: Optimizing FME Workflows with Parameters
Essentials of Automations: Optimizing FME Workflows with ParametersEssentials of Automations: Optimizing FME Workflows with Parameters
Essentials of Automations: Optimizing FME Workflows with Parameters
 
Search and Society: Reimagining Information Access for Radical Futures
Search and Society: Reimagining Information Access for Radical FuturesSearch and Society: Reimagining Information Access for Radical Futures
Search and Society: Reimagining Information Access for Radical Futures
 
JMeter webinar - integration with InfluxDB and Grafana
JMeter webinar - integration with InfluxDB and GrafanaJMeter webinar - integration with InfluxDB and Grafana
JMeter webinar - integration with InfluxDB and Grafana
 
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...
 
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
Dev Dives: Train smarter, not harder – active learning and UiPath LLMs for do...
 
ODC, Data Fabric and Architecture User Group
ODC, Data Fabric and Architecture User GroupODC, Data Fabric and Architecture User Group
ODC, Data Fabric and Architecture User Group
 
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
From Daily Decisions to Bottom Line: Connecting Product Work to Revenue by VP...
 
GraphRAG is All You need? LLM & Knowledge Graph
GraphRAG is All You need? LLM & Knowledge GraphGraphRAG is All You need? LLM & Knowledge Graph
GraphRAG is All You need? LLM & Knowledge Graph
 
Mission to Decommission: Importance of Decommissioning Products to Increase E...
Mission to Decommission: Importance of Decommissioning Products to Increase E...Mission to Decommission: Importance of Decommissioning Products to Increase E...
Mission to Decommission: Importance of Decommissioning Products to Increase E...
 
State of ICS and IoT Cyber Threat Landscape Report 2024 preview
State of ICS and IoT Cyber Threat Landscape Report 2024 previewState of ICS and IoT Cyber Threat Landscape Report 2024 preview
State of ICS and IoT Cyber Threat Landscape Report 2024 preview
 
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptxIOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
IOS-PENTESTING-BEGINNERS-PRACTICAL-GUIDE-.pptx
 
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
Empowering NextGen Mobility via Large Action Model Infrastructure (LAMI): pav...
 
The Future of Platform Engineering
The Future of Platform EngineeringThe Future of Platform Engineering
The Future of Platform Engineering
 
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...
 
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
From Siloed Products to Connected Ecosystem: Building a Sustainable and Scala...
 
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
Unsubscribed: Combat Subscription Fatigue With a Membership Mentality by Head...
 

Scala with mongodb

  • 1. Scala with MongoDB Abdhesh Kumar Email: abdhesh@knoldus.com Twitter:@abdheshkumar90
  • 2. Agenda 1. What is MongoDB? 2. Why we use MongoDB? 3. What are the MongoDB Terminologies? 4. How to Install and Use MonogDB? 5. What are the Operators of MongoDB? 6. What is Casbah? 7. What is Salat?
  • 3. What is MongoDB? ➢ MongoDB is a document-oriented database management system designed for performance, horizontal scalability, high availability,open source NoSQL database(Schemaless or Non-relational) ,And advanced queryability. ➢ MongoDB is a document-based database system, and as a result, all records, or data, in MongoDB are documents.
  • 4. Why we use MongoDB? Document Oriented ➢ Documents (objects) map nicely to programming language data types. ➢ Dynamically-typed (schemaless) for easy schema evolution. ➢ No joins and no transactions for high performance and easy scalability High Performance ➢ No joins and no transactions makes reads and writes fast ➢ Indexes can include keys from embedded documents and arrays. ➢ Optional asynchronous writes .
  • 5. High Availability ➢Replicated servers with automatic master failover. Easy Scalability ➢ Automatic sharding distributes collection data across machines. ➢Reads and writes are distributed over shards Flexibility ➢MongoDB stores data in JSON documents (which we serialize to BSON).
  • 6. Indexing ➢ MongoDB supports generic secondary indexes, allowing a variety of fast queries,and provides unique, compound, and geospatial indexing capabilities as well. Fixed-size collections ➢ Capped collections are fixed in size and are useful for certain types of data, such as logs. ➢ Real time aggregation ➢ Rich query capabilities ➢ Geospatial features ➢ Flexible schema
  • 7. MongoDB Terminologies Sql Terms/Concepts MongoDB Terms/Concepts database database table collection index index row Document or *BSON document column Field or BSON field join *Embedding and linking Primary key _id Group by aggregation
  • 8. MongoDB Terms/Concepts Documents: ➢ The concept of a document: an ordered set of keys with associated values. ➢ documents are represented as objects: {"greeting" : "Hello, world!"} Collections: ➢ A collection is a group of documents.
  • 9. Embedding: ➢ “Embedding is the nesting of objects and arrays inside a BSON document” Linking: ➢ “Links are references between documents” Aggregation: ➢ The MongoDB aggregation framework provides a means to calculate aggregated values without having to use map-reduce. ➢ If you’re familiar with SQL, the aggregation framework provides similar functionality to GROUP BY and related SQL operators as well as simple forms of “self joins.” Additionally, the aggregation framework provides projection capabilities to reshape the returned data.
  • 10. What is JSON? ➢ JSON (JavaScript Object Notation) is a lightweight data-interchange format. ➢ JSON is built on two structures: 1. A collection of name/value pairs. ex.object, record, struct, dictionary, hash table, keyed list, or associative array 2. An ordered list of values. ex. array, vector, list, or sequence
  • 11. { "_id" : 1, "name" : { "first" : "Rohan", "last" : "Singh" }, "contributes" : [ "TypeSafe", "Knoldus" ], "awards" : [ { "award" : "Play Framework Expert", "year" : 2012, "by" : "TypeSafe" }, { "award" : "Scala Expert", "year" : 2013, "by" : "Knoldus" } ] }
  • 12. What is BSON? ➢ BSON is a binary-encoded serialization of JSON-like document. ➢ BSON supports the embedding of documents and arrays within other documents and arrays. ➢ MongoDB uses BSON as the data storage and network transfer format for “documets”.
  • 13. Install MongoDB $ wget http://downloads.mongodb.org/osx/mongodb-osx-x86_64-2.0.6.tgz $ tar -zxvf mongodb-osx-x86_64-2.0.6.tgz $ sudo mkdir -p /data/db $ sudo chown `id -u` /data/db
  • 14. Starting MonDB and Mongo Shell ➢ $ ./bin/mongod ➢ $ mongo MongoDB shell version: 2.4.1 connecting to: test >
  • 15. MongoDB Operators Query Selectors: ➢ Comparison $all, $gt, $gte, $in, $lt, $lte, $ne, $nin ➢ Logical $and, $or, $nor, $not ➢ Element $exists, $mod, $type ➢ JavaScript $regix, $where
  • 16. ➢ Array $elemMatch,$size Update ➢ Fields $inc, $set, $unset ➢ Array $, $addToSet, $pop, $pullAll, $pull, $pushAll, $push Projection $, $elemMatch, $slice
  • 17. What is the Casbah? ➢ Casbah is a Scala toolkit for MongoDB—We use the term “toolkit” rather than “driver”, as Casbah integrates a layer on top of the official mongo-java-driver for better integration with Scala.
  • 18. Installing & Setting up Casbah *You should have MongoDB setup and running on your machine. Add casbah dependencies to buid.sbt resolvers += "Scala-tools" at "https://oss.sonatype.org/content/groups/scala-tools" resolvers += "Sonatype Snapshot" at "https://oss.sonatype.org/content/repositories/releases" libraryDependencies ++= Seq( "org.mongodb" % "casbah_2.10" % "2.5.1" )
  • 19. Use Casbah with Scala ➢ Import the Driver import com.mongodb.casbah.Imports._ ➢ Connecting to MongoDB Connect to default - localhost, 27017 val mongoConnection = MongoConnection() connect to "mongodb01" host, default port val mongoConnection = MongoConnection("mongodb01") connect to "mongodb02" host, port 42017 val mongoConnection = MongoConnection("mongodb02", 42017)
  • 20. val mongoDB = mongoConnection("casbah_test") Connect casbah_test database with test_data collecion by chaining val mongoColl = mongoConnection("casbah_test")("test_data") Working with Collections
  • 21. What is Salat? ➢ Salat is a bi-directional Scala case class serialization library. ➢ Salat provides fast, reliable bi-directional serialization between Scala case classes and MongoDB's DBObject format. ➢ case classes can be used directly for storing document by simply declaring a DAO and with the help of some annotations
  • 22. Salat DAO SalatDAOmakes it simple to start working with your case class objects. Use it as is or as the basis for your own DAO implementation. By extending SalatDAO, you can do the following out of box: ➢ insert and get back an Option with the id ➢ findOne and get back an Option ➢ typed to your case class ➢ find and get back a Mongo cursor typed to your class ➢ iterate, limit, skip and sort ➢ update with a query and a case class ➢ save and remove case classes ➢ Projections ➢ built-in support for child collections
  • 23. What Scala types can Salat handle? ➢ case classes ➢ embedded case classes ➢ embedded case classes typed to a trait or abstract superclass annotated with @Salat ➢ Scala enums ➢ Options ➢ Collections Collections ➢ Maps are represented as DBObject ; all other collections turn into DBList .
  • 24. Salat collection support Salat 0.0.8-SNAPSHOT and above support the following mutable and immutable collections: ➢ Map ➢ Lists and linked lists ➢ Seqs and indexed seqs ➢ Set ➢ Buffer ➢ Vector
  • 25. Salat Unsupported types Salat can't support any of these types right now: ➢ Nested inner classes ➢ A class typed at the top-level to a trait or an abstract superclass Salat can't support these types because the mongo-java-driver doesn't support Them: ➢ Any type of Map whose key is not a String ➢ any type of map whose key is a String containing . or $
  • 26. Salat Supports Annotations Salat offers the following annotations to customize serialization behavior: ➢ @Salat to support polymorphic instances of a trait or abstract superclass ➢ @Key to change the name of a field ➢ @Persist to serialize a value outside the case class constructor ➢ @Ignore to ignore a field in the case class constructor ➢ @EnumAs to customize the behavior of a particular enum
  • 27. Salat Grater Grater Salat as the notion of Grater that is responsible to the de/serialization of a case class. This through two simple functions, let have a Grater for the type T: ➢ asDBObject(t:T) : returns a MongoDB representation of t ➢ asObject(dbo:DBObject)[T] : returns a T instance based on the provided Mo ngoDB content
  • 28. Installing & Setting up Salat Add salat dependencies to buid.sbt resolvers += "Novus Release Repository" at "http://repo.novus.com/releases/" resolvers += "Sonatype OSS Snapshots" at " https://oss.sonatype.org/content/repositories/snapshots" libraryDependencies ++= Seq( "com.novus" %% "salat" % "1.9.2-SNAPSHOT" )