{tecnologia, conceitos, negócios, idéias, práticas, .NET, ruby, osx, ios e algo mais}
14/05/2011
Fala galera. Não é bem de hoje que minha "revolta" com bancos de dados relacionais começou. Eu acho sim que os bancos relacionais possuem sua serventia, mas eu comecei a desconfiar que eles não eram a "bala de prata" e solução para todos os problemas do mundo(incluindo a fome e a miséria como pregam os DBAs).Eu também sempre questionei a normalização e des(ou de)normalização. Acho que o ato de des(ou de)normalizar algo em um banco relacional já é um indício de que algo está fora dos padrões.Bom eu não vou tentar envangelizar ninguém sobre soluções não relacionais e NoSQL, etc. Apenas quero compartilhar um pouco das minhas aventuranças(pouco mais de 2h de leituras e console applications) com vocês tentando expandir um pouco o batbelt :P
Decidi começar a brincadeira com o MongoBD. Não sei exatamente o que me levou a começar com o Mongo, poderia ter sido Cassandra, Redis, CouchDB, RavenDB.
MongoDB (from "humongous") is a scalable, high-performance, open source, document-oriented database. Written in C++.
MongoDB é baseado em documentos. Estes documentos são armazenados utilizando BSON(Binary JSON).Digamos, a grosso modo, que um documento é um grafo de objetos. Desta maneira você armazena grafos de objetos e não linhas de dados.A normalização no MongoDB se dá neste nível. Você deve analisar quais objetos "merecem" ter sua própria collection no database e quais devem apenas estar contidos dentro de outros documentos.Veja esta imagem do próprio site do MongoDB:
Nesta imagem podemos ver que o documento student possui dentro dele um documento address e documentos score. Isto quer dizer que não há necessidade de address e score terem suas "próprias tabelas".Além disso existe uma collection para os documents course.Isto é apenas uma das particularidas do MongoDB. Vocês podem conferir uma série de features e seus detalhamentos no próprio site do MongoDB: - Indexes - Replication & High Availability - Auto-Sharding - Querying - Fast In-Place Updates - Map/Reduce
Bom eu estou usando um Mac mas o processo de instalação para o Windows é bastante simples e possui um tutorial completo no próprio site do Mongo: http://www.mongodb.org/display/DOCS/Quickstart+Windows.Não há mistério algum, basta executar o arquivo "mongod.exe" e o servidor Mongo estará rodando.No Mac é o mesmo processo.
Para iniciar o servidor Mongo abra o terminal(ou o cmd) e execute o mongod.Abra então outro terminal(cmd) e execute o mongo. Com isso realizaremos operações no nosso servidor Mongo.# Executando operações no servidor Mongo Vamos listar os databases existentes no nosso servidor:
show dbs;
A saída deve ser parecida com esta:
> show dbs;
admin(empty)local(empty)
Para criar um novo database vamos executar simplesmente o comando use:
> use meu_novo_database;
switched to db meu_novo_database
Pronto! Database criado.
Vamos então criar alguns documentos em uma collection chamada Pessoas:
> db.Pessoas.insert({
ome: "vinicius", idade: 25}
);
> db.Pessoas.insert({
ome: "willy wonka", idade: 31}
);
Acima inserimos dois documentos na collection Pessoas.
Vamos então selecionar nossos documentos:
> db.Pessos.find();
Este comando vai nos retornar um cursor para os elementos da nossa collection. Neste caso veremos a seguinte saída no terminal:
> db.Pessoas.find();
{ "_id" : ObjectId("4dcec4b993d74e78121d4312"), "nome" : "vinicius", "idade" : 25 }
{ "_id" : ObjectId("4dcec57e93d74e78121d4313"), "nome" : "willy wonka", "idade" : "?" }
Para selecionarmos apenas um documento filtrando por alguma de suas propriedades:
> db.Pessoas.find({
dade:25}
);
{ "_id" : ObjectId("4dcec4b993d74e78121d4312"), "nome" : "vinicius", "idade" : 25 }
Bom galera com isso acho que conseguimos instalar e começar a brincar com o MongoDB. Para os próximos posts eu vou mostrar de fato como utilizá-lo em aplicações .NET/Mono.É importante dar uma lida na documentação e principalmente nos conceitos e particularidades de bancos não relacionais.Eu gostaria ainda de deixar uma provocação: não são os devs que precisam convencer os DBAs de que uma solução NoSQL/Não relacional é a ideal, mas os DBAs devem convencer os devs de que a solução relacional é a melhor.Abraços e bons estudos.Vinicius Quaiato.