- NoSQL East 2009 - https://nosqleast.com/2009/
- NoSQL BErlin - http://nosqlberlin.de/
Most interesting summaries and other resources I found from these events:
- NoSQL East 2009 - Summary of Day 1 by @uggedal
- NoSQL East 2009 - Summary of Day 2 by @uggedal
- NoSQL East 2009 Redux by Jon Moore
- NoSQL Berlin Meetup Notes by Phillip Oertel
- NoSQL Berlin slides
- NoSQL Berlin videos
The NoSQL Hype
As usual, the "NoSQL" moniker keeps being a bit irritating to me. Some of the stores qualified as "NoSQL" only aim at being efficient DHTs.
I am NOT against innovation. My problem with many "NoSQL" solutions is that:
History Repeating
So, while there are many interesting Open Source solutions qualified as "NoSQL" popping up, there is too much hype around the "NoSQL" moniker. Too much old stuff dressed in new clothes and too many lessons from the past being ignored.
Like MVCC, which is being considered by some databases as the magic bullet of data merging, while the lessons learned about its limitations (by communities like the Interbase or Firebird users) are being ignored. This article, for instance, documents how MVCC does not detect data inconsistencies when merging two changesets if the inconsistency is related to data that is only read (resulting in data written to another row/table):
Besides, Key/value stores are VERY OLD NEWS.
Some old stores are still around, proofed by the years of use and still damn efficient, like Berkeley DB.
NoSQL interfaces being more productive that using SQL for all data manipulation is the dream of those who are too lazy to learn SQL. But then it is just a dream.
As usual, the "NoSQL" moniker keeps being a bit irritating to me. Some of the stores qualified as "NoSQL" only aim at being efficient DHTs.
But those that aim at being databases end up having some kind of query language, although often a really poor one - which means query languages have their use...
And nothing prevents you from using a sharded (even with mirrored shards) MySQL database as a key store - and many companies are doing just that.
I am NOT against innovation. My problem with many "NoSQL" solutions is that:
- They do NOT present enough progress while ignoring lessons from past experience;
- They pretend to innovate some backend aspects while sending you back in time on the API / interface side;
- They pretend to be revolutionary while doing nothing better that well known commercial solutions (e.g. Coherence).
History Repeating
So, while there are many interesting Open Source solutions qualified as "NoSQL" popping up, there is too much hype around the "NoSQL" moniker. Too much old stuff dressed in new clothes and too many lessons from the past being ignored.
Like MVCC, which is being considered by some databases as the magic bullet of data merging, while the lessons learned about its limitations (by communities like the Interbase or Firebird users) are being ignored. This article, for instance, documents how MVCC does not detect data inconsistencies when merging two changesets if the inconsistency is related to data that is only read (resulting in data written to another row/table):
Besides, Key/value stores are VERY OLD NEWS.
Some old stores are still around, proofed by the years of use and still damn efficient, like Berkeley DB.
But I used even older key/value stores, like the initial versions of c-tree or the Turbo Pascal Database Toolbox from Borland. What I can tell you, from experience, is:
- It is much more productive to work with SQL (but you need to learn it);
- SQL is not just a programming tool. It is a precious database administration tool too.
So, the revolution is not having NoSQL but having better databases and a Better SQL.
Don't forget how many persistency layers already tried to kill SQL and failed miserably. Sure, they are OK for basic CRUD tasks, but most applications end up needing much more than that.
To put some hype back on SQL, lets remember how it is truly a DSL.
Don't forget how many persistency layers already tried to kill SQL and failed miserably. Sure, they are OK for basic CRUD tasks, but most applications end up needing much more than that.
To put some hype back on SQL, lets remember how it is truly a DSL.
NoSQL interfaces being more productive that using SQL for all data manipulation is the dream of those who are too lazy to learn SQL. But then it is just a dream.
Cutting the Hype
Since what else I have to say was already said, I will just point to the other guys:
- NoSQL: If Only It Was That Easy by BJ Clark
- The Trouble with NoSQL by Stuart Charlton
- NoSQL isn’t a movement by BJ Clark
Nice work cutting through the crap... I too was perplexed by the demonisation of SQL (which completely misses the point of the consistency vs scalability tradeoff). The best characterisation I've seen of the NoSQL "movement" is as a temper tantrum by those who don't like SQL and having tried twice to open up the community by finding a more sensible alternative I'm pretty much over it. The technology itself is still cool though... it just means that I'll continue to present it independently rather than benefiting from (and contributing to) their effort. NoSQL is nothing new but a bad attitude.
ReplyDeleteSam