Uma dúvida que surgiu em nosso fórum era sobre como alterar o tipo de tabela InnoDB para MyISAM, ou vice-versa. Bom aparentemente não estamos questionando o porque de modificar o tipo da tabela. Cada desenvolvedor deve saber qual o melhor formato a utilizar em sua aplicação. Nós temos um artigo falando sobre as diferenças entre InnoDB e MyISAM, quais os benefícios de cada uma e quais vantagens também.

Eu particularmente prefiro utilizar MyISAM pois acredito que seja mais rápido, como pouco uso chave estrangeira aplicada de fato a tabela. Nas minhas aplicações eu faço o controle de registros em tabelas externas em código e não no banco de dados, assim posso utilizar os benefícios da performance do MyISAM.

O InnoDB não tem uma otimização especial para criação de índices separados. Assim não há custo para exportar e importar a tabela e criar índices posteriormente. O modo mais rápido de se alterar uma tabela para InnoDB é fazer as inserções diretamente em uma tabela InnoDB, isto é, usando o ALTER TABLE ... ENGINE=INNODB, ou então você pode criar uma tabela InnoDB vazia com definições idênticas e insirir os registro com INSERT INTO ... SELECT * FROM ...

Depois de todos os dados serem inseridos você pode renomear as tabelas. Durante a conversão de tabelas grandes você deve configurar á área de buffer com um tamanho grande para reduzir a E/S de disco. Não deve ser maior que 80% da memória física.

Como alterar os tipos de tabela com linha de comando

Criamos uma tabela chamada teste dentro do banco de dados teste. Já devidamente logado com usuário root.

CREATE TABLE `teste`.`teste` (
`id` INT( 11 ) NOT NULL ,
`titulo` VARCHAR( 200 ) NOT NULL ,
PRIMARY KEY ( `id` ) 
) ENGINE = MYISAM ;

Para alterar a tabela teste para InnoDB execute o seguinte comando:

ALTER TABLE `teste` ENGINE = InnoDB

Para fazer o contrário, transformar InnoDB para MyISAM execute o seguinte comando:

ALTER TABLE `teste` ENGINE = MYISAM

Como alterar então os tipos usando o phpMyAdmin:

No phpMyAdmin, crie uma tabela chamada teste, com os campos id INT(11) e titulo VARCHAR(200).

Defina o nome da tabela teste e clique em executar. Após isto aparecerá uma tela pedindo para colocar os campos.

Defina o nome dos campos id INT(11) e faça ele como chave primária, e outro campo chamado titulo VARCHAR(200). Você pode definir o tipo da tabela, no caso escolhi MyISAM. E depois clique em executar.

Feito isto, acesse a tabela teste, na barra lateral esquerda, e então clique na aba operações, vai ter uma caixa chamada Opções da tabela, tem um campo chamado Storage Engine, basta escolher o tipo que quiser para alterar e apertar o botão executar.

Atenção: Certifique-se de que você não irá ocupar todo o tablespace: tabelas InnoDB gasta muito mais espaço que tabelas MyISAM. Se um ALTER TABLE ficar sem espaço, ele irá iniciar um rollback, que pode levar horas se ele estiver no limite de disco. Para inserções, o InnoDB utiliza o buffer de inserção para fundir registros de índices secundários a índices em grupos. Isto economiza muito a E/S de disco.


Qualquer dúvida pergunte no formulário abaixo ;)