Skip to content

Latest commit

 

History

History
70 lines (55 loc) · 3.47 KB

Armazenamento_de_Dados.md

File metadata and controls

70 lines (55 loc) · 3.47 KB

Armazenamento de dados

Nas últimas décadas do século XX o banco de dados relacional tornou-se tão importante que era praticamente uma unanimidade. Até que Amazon.com e Google publicaram papers seminais revelando que utilizavam internamente bancos de dados não relacionais projetados para escalar horizontalmente -- algo que sempre foi muito difícil no modelo relacional normalizado.

Esse movimento deu origem ao termo NoSQL que significa "não SQL" ou "não apenas SQL" (Not Only SQL), dependendo de quem define. Em projetos de alguma complexidade não é raro o uso de um banco de dados relacional junto com um ou mais bancos de dados não-relacionais. Essa tendência é conhecida como "Polyglot Persistence", termo cunhado pelo nosso colega Neal Ford e popularizado por outro colega, o Martin Fowler, em seu blog.

Conheça bem o modelo relacional e a linguagem SQL

Adquira prática com um gerenciador banco de dados relacional

Os mais importantes GBDR no mercado são:

Além desses sistemas para servidores, também é importante a SQLite, uma biblioteca em C com pacotes para várias linguagens de programação que permite gerenciar um banco de dados relacional no mesmo processo de uma aplicação. Por economizar recursos, essa solução é muito popular em aplicativos mobile nativos.

Conheça alguns modelos diferentes de banco de dados não-relacional

Não é fácil categorizar os bancos de dados não-relacionais -- eles são muito diversificados em seus modelos de dados e características operacionais. Uma boa analogia é pensar que bancos de dados não-relacionais são veículos especializados, tão especializados que muitas vezes não faz sentido compará-los porque não concorrem para os mesmos casos de uso.

Mesmo entre sistemas que possuem modelos de dados parecidos, há diferenças importantes de arquitetura. Por exemplo, o MongoDB e o CouchDB ambos adotam o modelo de dados documental, com registros complexos, aninhados e sem esquemas pré-definidos. Porém o MongoDB é otimizado para cenários de atualizações frequentes, enquanto o CouchDB não lida tão bem com atualizações rápidas mas é mais avançado na sincronização entre réplicas distribuídas de forma descentralizada (sem mestres).

Bancos de dados documentais

Recursos