Академический Документы
Профессиональный Документы
Культура Документы
É muito fácil encontrar serviços de hospedagem de sites que oferecem em seus planos os
Sistemas Gerenciadores de Banco de Dados (SGDB) MySQL e PostgreSQL, embora isso seja
mais comum com o primeiro. Como esses SGBD não são usados apenas na internet, talvez
seja de seu interesse utilizá-los em seus projetos de software, uma vez que cada um é dotado
de vantagens interessantes, como a gratuidade de uso. Para ajudá-lo a escolher o melhor para
sua aplicação, este artigo apresenta as principais características de ambos, começando com o
MySQL. Para tanto, é recomendável que você tenha algum conhecimento sobre os conceitos
de bancos de dados.
Alguns termos
Mesmo aquelas pessoas que já trabalham com banco de dados podem ficar "perdidas" no meio
de tantos nomes de recursos. Assim, para facilitar a compreensão, segue uma lista com uma
breve explicação sobre os recursos mais importantes:
O MySQL é um dos sistemas de gerenciamento de banco de dados mais populares que existe
e, por ser otimizado para aplicações Web, é amplamente utilizado na internet (inclusive aqui no
InfoWester). É muito comum encontrar serviços de hospedagem de sites que oferecem o
MySQL e a linguagem PHP, justamente porque ambos trabalham muito bem em conjunto.
Outro fator que ajuda na popularidade do MySQL é sua disponibilidade para praticamente
qualquer sistema operacional, como Linux, FreeBSD (e outros sistemas baseados em Unix),
Windows e Mac OS X. Além disso, o MySQL é um software livre (sob licença GPL), o que
significa que qualquer um pode estudá-lo ou alterá-lo conforme a necessidade.
- Alta compatibilidade com linguagens como PHP, Java, Python, C#, Ruby e C/C++;
- Baixa exigência de processamento (em comparação como outros SGBD);
- Vários sistemas de armazenamento de dados (batabase engine), como MyISAM, MySQL
Cluster, CSV, Merge, InnoDB, entre outros;
- Recursos como transactions (transações), conectividade segura, indexação de campos de
texto, replicação, etc;
- Instruções em SQL, como indica o nome.
Até o momento em que este artigo era escrito, o MySQL estava na versão 5.0 (mais
precisamente, 5.0.26). Em relação à versão 4.0, houve acréscimo de vários recursos e
melhorias importantes, como:
- Triggers;
- Stored procedures;
- Sub-selects;
- Suporte total ao Unicode;
- INFORMATION_SCHEMA (para armazenamento do dicionário de dados);
- Server side cursors;
- Suporte a SSL;
- Melhoria no tratamento de erros.
O MySQL surgiu na Suécia pelas mãos de três colegas: Allan Larsson, David Axmark e Michael
Monty Widenius. Trabalhando com base de dados, eles sentiram a necessidade de fazer
determinadas conexões entre tabelas e usaram o mSQL para isso. Porém, não demorou para
perceberem que essa ferramenta não lhes atendia conforme o necessário e passaram a
trabalhar em uma solução própria. Surgia então o MySQL, cuja primeira versão foi lançada no
ano de 1996.
Um fato importante a ser destacado sobre o MySQL é que esse SGBD também possui uma
licença comercial, isto é, paga. A MySQL AB, empresa que o desenvolve e que o distribui,
oferece suporte diferenciado a quem estiver disposto a pagar por isso.
Em 1996, quando o projeto estava estável, o banco de dados recebeu o nome de PostgreSQL.
No entanto, enquanto ainda possuía o nome Postgres95, o banco de dados teve várias
mudanças. O seu código foi totalmente revisado e a linguagem SQL foi definida como padrão.
No momento em que este artigo era escrito, o PostgreSQL estava na versão 8.1.
MySQL x PostgreSQL
MySQL ou PostgreSQL, qual usar? Ambos são muito bons e não fazem feio diante das
alternativas pagas. Além disso, possuem recursos e vantagens em comum, o que significa que,
para a maioria das aplicações, ambos podem ser usados. Na verdade, o correto não é tentar
descobrir qual é o melhor, mas em que situação um ou outro deve ser utilizado.
O PostgreSQL é otimizado para aplicações complexas, isto é, que envolvem grandes volumes
de dados ou que tratam de informações críticas. Assim, para um sistema de comércio
eletrônico de porte médio/alto, por exemplo, o PostGreSQL é mais interessante, já que esse
SGBD é capaz de lidar de maneira satisfatória com o volume de dados gerado pelas operações
de consulta e venda.
O MySQL, por sua vez, é focado na agilidade. Assim, se sua aplicação necessita de retornos
rápidos e não envolve operações complexas, o MySQL é a opção mais adequada, pois é
otimizado para proporcionar processamento rápido dos dados e tempo curto de resposta sem
exigir muito do hardware. Se você precisa, por exemplo, de um banco de dados para
armazenar o conteúdo do seu site, de seu fórum ou necessita manter um cadastro de usuários
de um portal, o MySQL "serve como uma luva", pois tais aplicações não necessitam dos
recursos avançados que o PostgreSQL oferece.
Para escolher um destes dois SGBD, procure entender bem quais recursos sua aplicação
precisa. Tente estimar o volume de dados, avalie o hardware disponível, certifique-se das
funcionalidades necessárias e, posteriormente, procure por informações mais detalhadas do
MySQL e do PostGreSQL. Se sua aplicação for simples - principalmente se for algo ligado à
internet -, não é preciso pensar muito: o MySQL é uma escolha satisfatória, pois é facilmente
encontrado em serviços de hospedagem.
Todavia, há situações em que tanto o MySQL quanto o PostgreSQL serão boas escolhas.
Nesses casos, é recomendável fazer testes com ambos e avaliar qual oferece mais vantagens
à aplicação.
Finalizando
Um banco de dados pode ser a diferença entre ter e não ter um negócio, seja ele de qualquer
porte. Por isso, a escolha deve ser bem feita e aspectos como desempenho, recursos,
documentação e suporte devem ser considerados. Em todos esses pontos o MySQL e o
PostgreSQL são excelentes, por isso, a escolha entre um deles só depende de sua aplicação.