Eu realmente não gosto do nome "NoSQL", porque não é muito descritivo. Ele me diz o que os bancos de dados não estão onde estou mais interessado no que são os bancos de dados . Eu realmente acho que essa categoria realmente abrange várias categorias de banco de dados. Estou apenas tentando ter uma idéia geral de qual trabalho cada banco de dados específico é a melhor ferramenta.
Algumas suposições que eu gostaria de fazer (e pediria que você fizesse):
- Suponha que você tenha a capacidade de contratar qualquer número de engenheiros brilhantes, com experiência igual em todas as tecnologias de banco de dados que já existiram.
- Suponha que você tenha a infraestrutura técnica para oferecer suporte a qualquer banco de dados (incluindo servidores e administradores de sistemas disponíveis que podem dar suporte ao referido banco de dados).
- Suponha que cada banco de dados tenha o melhor suporte possível gratuitamente.
- Suponha que você tenha 100% de adesão da gerência.
- Suponha que você tenha uma quantidade infinita de dinheiro para jogar no problema.
Agora, percebo que as suposições acima eliminam muitas considerações válidas envolvidas na escolha de um banco de dados, mas meu foco é descobrir qual banco de dados é melhor para o trabalho em um nível puramente técnico. Portanto, dadas as premissas acima, a pergunta é: para quais trabalhos cada banco de dados (incluindo SQL e NoSQL) é a melhor ferramenta e por quê?
Respostas:
Os bancos de dados relacionais (SQL) são ótimos para dados em que o modelo subjacente permanece estável. Muitas implementações já existem há algum tempo (Oracle, DB2, SqlServer) e são estáveis e seguras. Além disso, é muito fácil encontrar pessoas experientes para administrá-las - e os administradores de banco de dados são obrigatórios! Os programadores não precisam lidar com permissões, configuração e ajuste. Eles devem ser capazes de se concentrar na programação e deixar que os administradores se preocupem em manter o banco de dados ativo. Os bancos de dados relacionais também são relativamente fáceis de consultar e existem muitas ferramentas disponíveis para ajudar a encontrar dados a partir deles.
fonte
SQL
Objeto relacional. Servidores estáveis com controle de granulação fina sobre permissões.
NoSQL
Armazenamento flexível. Alta capacidade de escalabilidade e sharding.
fonte
Há algumas informações muito boas sobre isso neste artigo: Comparação Cassandra vs MongoDB vs CouchDB vs Redis vs Riak vs HBase vs Membase vs Neo4j :
fonte
Eu acho que essa não é uma boa pergunta, por exemplo, que tipo de veículo é bom? Bugatti, BWM, automóvel, mini-máquina, trem, locomotiva, avião?
depende da sua situação,
fonte