MySQL = MariaDB? – mysql banco-de-dados mariadb

Pergunta:


Já faz alguns dias em que esculto nas minhas aulas o professor dizendo:

A oracle comprou o MySQL e apenas o renomeou para MariaDB.

Como não sou de acreditar fácil nas coisas faladas, fui pesquisar sobre o assunto e pelo pouco que li, entendi que não houve essa “substituição” e que MySQL e MariaDB não são o mesmo.

Afinal, o DB MySQL é a mesma coisa que o MariaDB? Se não, qual a diferença entre eles?

Autor da pergunta Jorge.M

Guilherme Nascimento

Seu professor está enganado, MariaDB é compatível em muitas coisas com MySql, mas não é nada renomeado, é outro banco de qualquer forma, pode ser até considerado uma fork do mysql, já que foi criado pelo mesmo desenvolvedor do mysql.

Ou seja são projetos a parte, tanto que ambos recebem atualizações, melhorias e correções independente um do outro.

A maioria das estruturas de banco simples criadas para Mysql poderão funcionar no MariaDB e vice-versa (com um ou outro ajustes as vezes sendo necessário). O MariaDB se eu não me engano tem suporte para innoDB e myIsam, mesmos motores usados no mysql, mas também possui um motor chamado XtraDB (note que apesar de não ser padrão no Mysql é possivel usa-lo nele também, mas isto é outra história).

O MySql agora pertence a empresa Oracle e é mantido ainda e continua sendo desenvolvido e evoluiu bastante desde que virou um produto dela, já o mariaDB é mantido pelas empresas MariaDB Corporation Ab e MariaDB Foundation (conforme wikipédia).

No link a seguir contém as incompatibilidades entre ambos (a partir das versões MariaDB 5.1 e MySQL 5.1):

Incompatibilidade nas versões MariaDB 10.2 and MySQL 5.7 (creio que sejam as mais recentes):


Um resumo breve da história do porque nasceu o MariaDB

Mysql foi criada pelo Michael “Monty” Widenius e David Axmark, a Sun adquiriu a empresa Mysql AB, adquirindo assim o produto mysql, Michael trabalhou inicialmente para eles, mas ficou insatisfeito, não sei dizer se foi com o resultado do projeto ou com a empresa em si, e por isto deixou a Sun.

A Sun que foi fundada em 1982 então foi absorvida pela empresa Oracle entre 2009 e 2010, deixando assim de existir e os produtos que a ela pertenciam, como Java e o Mysql, passaram a pertencer a Oracle.

Em 2009 mesmo Monty (Michael) criou uma fork (‘cópia’) do Mysql dando a este sistema o nome de sua filha, Maria, e assim nascia o MariaDB.

Em meados de 2012 Monty (Michael) junto com David criaram a empresa MariaDB Foundation


Concluindo

Mysql e MariaDB podem ser compatíveis em quase tudo, mas possuem diversas incompatibilidades atualmente.

  • O Mysql é mantido e continua a evoluir pelas “mãos” da Oracle.
  • O MariaDB é mantido e continua a evoluir pelas “mãos” de MariaDB Corporation Ab e MariaDB Foundation.

Ambos são desenvolvidas atualmente por empresas diferentes, sem quaisquer ligação e creio que assim podemos considerar ambos sistemas concorrentes.

Em 2008, o projeto MySql foi incorporado pela Sun Microsystems. Em 2009, a Oracle comprou a Sun – e incorporou o MySql em seu rol de produtos. Não houve mudança no nome do produto. (Fonte).

O fundador do projeto, descontente com a situação, realizou um fork do MySql criando assim o MariaDB. (Fonte)

Pelo fato do MariaDB ser um fork do MySql, ambos (ainda) compartilham boa parte do código-fonte. Aparentemente, o projeto MariaDB tem se esforçado em manter-se altamente compatível com as novas versões do MySql (para seduzir usuários deste à migração daquele). Essa compatibilidade inclui sintaxe Sql, sistema de arquivos e protocolos de comunicação. Ou seja, na prática você inclusive pode usar um client de MySql para comunicar-se com o MariaDB, observados os devidos pareamentos de versão. (Fonte)

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *