About Me
Minneapolis, MN
Connect on Social Media
Twitter @jennstrater
LinkedIn https://linkedin.com/in/jennstrater
Github https://github.com/jlstrater
Agenda
Review of Relational Databases
Gr8Ladies Example Application
NoSQL Definition
Types of NoSQL data stores
Example
What will NOT be covered
Every aspect of every NoSQL solution
Implementation, maintenance, or scaling of NoSql databases
Relational Databases
Tabular
Defined Schema
Relationships between data
Terms
Database
Table
Row
Column
Groovy
Dynamic, compiled language for the Java Virtual Machine(JVM).
Interoperable with existing Java libraries
Concise, easy to read code
Used by many major companies including:
Groovy is a dynamic compiled language for the JVM. That mean’s it’s dynamic like languages you may
know like Python and PHP, but compiled for efficiency to run on the Java Virtual Machine aka the JVM.
Many of you may be asking, why learn yet another programming language? And granted, Groovy is not the best
language for every situation.
However, in a setting where productivity is paramount and you are looking for the stability of the known
architecture stack like Java, Groovy is the best choice.
As you’ll see, Groovy’s easy to learn, flexible syntax and interoperability with existing Java libraries, make
it a great language to add to your repertoire.
It's not just a prototyping solution and many companies use Groovy for enterprise solutions including Netflix,
LinkedIn, and Mutual of Omaha.
Grails
Groovy Based
Model View Controller(MVC) Web framework for the JVM
Convention over Configuration
Features including:
Object Relational Mapper(ORM)
Domain-Specific Languages(DSL)
Runtime and compile-time Metaprogramming
Extensive Plugin Support
Open-source community driven Project
New in Grails 3
Based on Spring Boot
Switched to Gradle for build system
Major structural changes
Example Task
Gr8Ladies Products
Catalog Products
Shopping Cart
What is NoSQL?
Not Only SQL
Group of data storage solutions that are not Relational Database Management System(RDBMS)
Schema-less
Non-relational
Originally NoSQL was used to refer to databases that did not use SQL or as 'not sql'. Over time, the phrase
has evolved to mean Not Only SQL. As a broad definition, NoSQL describes a group of storage solutions
that are not tabular like traditional relational databases.
Types of NoSQL solutions
Aggregate Stores
Key-value
Document
Column
Graph
Key-value Stores
Uses
Content Caching
Transient Data
Image Stores
Examples
MemCached
DynamoDB
Redis*
Considerations
Relationships
Transactions
Querying
Document Stores
Document stores are very similar to key value stores, but they allow for embedded structures
and a concept of hierarchy
Uses
Content Management Systems(CMS) / Blogging Platforms
Forms/data with many optional fields
Frequently Changing Schemas
Examples
CouchDB
RavenDB
Azure DocumentDB
MongoDB
Considerations
Complex transactions across documents
Complex searching
especially if searching is within the embedded structures
Column Family
Use Cases
CMS Systems/ Blogging Platforms
Log Aggregators
Incremental Counters
Examples
Cassandra
HBase
Hypertable
Considerations
Schema Changes
Arbitrary unstructured data
Graph Databases
Types
Labeled Property Graph
Hypergraphs
Triples
The figure I used is an example of a Labeled Property Graph. It contains nodes and relationships and each node
has properties which can be though of as key-value pairs. The relationships are named and have directionality.
This is the most common type of graph database.
The second type, a hypergraph, differs mainly by having a relationship connect any number of nodes. This is useful
for modeling relationships where multiple nodes (say Alice and Bob) relate to multiple other nodes(say their 3 cars).
Triple Stores are a semantic way of graphing data in examples that specify a subject, predicate, and then an object.
Uses
Social Networks
E-commerce Recommendations
Geo
Nearby Locations and Routing
Examples
Neo4J
OrientDB
Allegro Graph
Considerations
Deep tree traversals*
Very different way of thinking about data
Libraries & Plugins
Status
Native REST API
Neo4j GORM
Last Updated June 2014
Suggested Reading
Sadalage, Pramod J., and Martin Fowler. NoSQL Distilled: A Brief Guide to the Emerging World of Polyglot Persistence . Addison-Wesley Professional, 2012. Print.
Vardanyan, Mikayel. "Picking the Right NoSQL Database Tool." Monitis Blog . 22 May 2011. Web.
Copeland, Rick. MongoDB Applied Design Patterns . O'Reilly Media, 2013. Print.
Chinnachamy, Arun. Redis Applied Design Patterns . Packt Publishing, 2014. Print.
Robinson, Ian., Jim Webber, and Emil Eifrem. Graph Databases . O'Reilly Media, 2015. Print.
How do I pick just one?
You don't have to!
NoSQL data stores are meant to enhance existing solutions not be a one size fits all solution. Mix and match for various tasks.
Approach # 1
All In - MongoDB GORM
MongoDB
Terminology
Databases
Collections
Document
MongoDB Continued
Highlights
Created When Needed
Optional Fields
BSON Object Ids over Integers
Approach # 2
Partial - Grails-Redis plugin
Redis
Terminology
Highlights
Organized/Indexed Keys
CRUD operations
Key Expiration
Service Level Injection rather than all of GORM
Conclusion
Picking a NoSQL solution depends on the problem
Not every tool is the right one for the job
NoSQL stores are valid alternatives to relational databases
NoSQL solutions are highly supported in Groovy and Grails