Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Why NoSQL?
Search
John Nunemaker
PRO
December 30, 2010
Programming
10
820
Why NoSQL?
Keynote for WindyCityDB 2010. My thoughts on why NoSQL is taking off the way it is.
John Nunemaker
PRO
December 30, 2010
Tweet
Share
More Decks by John Nunemaker
See All by John Nunemaker
Atom
jnunemaker
PRO
7
3.2k
MongoDB for Analytics
jnunemaker
PRO
8
670
Addicted to Stable
jnunemaker
PRO
32
2.1k
MongoDB for Analytics
jnunemaker
PRO
21
2.1k
MongoDB for Analytics
jnunemaker
PRO
16
29k
Why You Should Never Use an ORM
jnunemaker
PRO
51
8.6k
Don't Repeat Yourself, Repeat Others
jnunemaker
PRO
7
3.2k
I Have No Talent
jnunemaker
PRO
14
840
Why MongoDB Is Awesome
jnunemaker
PRO
18
4.2k
Other Decks in Programming
See All in Programming
SwiftUIで使いやすいToastの作り方 / How to build a Toast system which is easy to use in SwiftUI
lovee
3
140
見た目から始める生産性向上
ikumatadokoro
7
830
⼤規模⾔語モデルの拡張(RAG)が 終わったかも知れない件について
nearme_tech
23
15k
単体テストを書かない技術 #phpcon_odawara
o0h
PRO
26
8.2k
Amazon SQSコンシューマー疎結合への旅 - 出張! #DevelopersIO IT技術ブログの中の人が語る勉強会 #3
quiver
0
260
Code Reviews
bkuhlmann
4
890
R言語の環境構築と基礎 Tokyo.R 112
bob3bob3
0
260
educure_カリキュラム生操作マニュアル.pdf
linew_official
0
750
Komplexe Oberflächen mit SVG und der Web Animation API
joergneumann
0
670
入門 AWS Amplify Gen2 / Introduction to AWS Amplify Gen2
genkiogasawara
1
330
Elm 0.19.0 Changes
bkuhlmann
0
490
VS Code をプロダクトにどう取り込むか
onomax
1
360
Featured
See All Featured
Building an army of robots
kneath
300
41k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
659
120k
Intergalactic Javascript Robots from Outer Space
tanoku
266
26k
Why Our Code Smells
bkeepers
PRO
331
56k
Making the Leap to Tech Lead
cromwellryan
124
8.5k
How to train your dragon (web standard)
notwaldorf
73
5.2k
Stop Working from a Prison Cell
hatefulcrawdad
266
19k
Debugging Ruby Performance
tmm1
70
11k
Building Flexible Design Systems
yeseniaperezcruz
319
37k
Typedesign – Prime Four
hannesfritz
36
2.1k
Web Components: a chance to create the future
zenorocha
305
41k
Documentation Writing (for coders)
carmenintech
60
3.9k
Transcript
Ordered List John Nunemaker WindyCityDB June 26, 2010 Why Is
NoSQL So Darn Popular?
Present Future Past
Present Future Past
1960s Linked Pointers
IDS Integrated Data Store
IMS Information Management System
1970s Relational Birth
Edgar Codd Relational Daddy
System R SEQUEL
Ingres Berkeley
Oracle Not of the Matrix kind
None
1980s Relational Boom
None
Reliability and Speed The Invention of Indexing
Flexibility Struggles Medicine, Physics, etc.
1990s - 2000s WWW and Client/Server
Present Future Past
What changed between the past and the present?
The Web Image Credit: http://code.google.com/apis/socialgraph/images/the-web.png
NoSQL Not Only SQL
The movement defined by what it is not.
So what is it?
Development Friendly
How do we store? Moving from...
None
How do we use? Moving to...
{ id : 3, user_id : 25, line_items: [ {
sku : '123', price: 1000, name : 'Nunemaker Autograph'}, { sku : '124', price: 1000, name : 'Banker Autograph'}, ], shipping_address: { street : '123 Some St.', city : 'South Bend', state : 'IN', zip : '11216' }, subtotal : 2000, tax : 140, total : 2140 }
Operations Friendly
instead of
Eventual Consistency
Single Item Transactions
Friends Galore!
None
Key/Value Fast and Simple
None
None
None
None
Eventually Consistent Key/Value
None
None
None
Document Rich Data Models
None
None
Relational Normalized and Solid
None
None
Present Future Past
Polyglot Persistence The future is
None
“ The Paradox of Choice Faced with one attractive option,
two-thirds of people are willing to go for it. But faced with two attractive options, only slightly more than half are willing to buy.
What if there are two attractive options and you have
two choices?
Hosted The future is
None
None
None
None
None
None
Bright The future is
Don’t get to know a database, get to know several.
Ordered List Thank you!
[email protected]
John Nunemaker WindyCityDB June 26,
2010 @jnunemaker