Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Cambiar tipo de tabla de MyISAM a InnoDB con consulta SQL
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Cambiar tipo de tabla de MyISAM a InnoDB con consulta SQL

Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
mysql
Invitado





Asunto: Cambiar tipo de tabla de MyISAM a InnoDB con consulta SQL Responder citando

¿Cómo puedo cambiar el tipo de tabla de MyISAM a InnoDB con una consulta SQL?

¿qué diferencia hay entre MyISAM y InnoDB?
MensajePublicado:
Mie Sep 06, 2006 5:27 am
Top of Page
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Cambiar tipo de tabla de MyISAM a InnoDB con consulta SQ Responder citando



Anuncios



mysql escribió:
¿Cómo puedo cambiar el tipo de tabla de MyISAM a InnoDB con una consulta SQL?


Para cambiar el tipo de tabla ejecutaremos la siguiente consulta SQL:

Código:
ALTER TABLE nombre_tabla ENGINE = InnoDB;



La diferencia principal entre el tipo MyISAM y el InnoDB es que MyISAM no permite transacciones, es decir, si ejecutamos una serie de consultas sql de modificación de datos no podremos controlar estas transacciones para validarlas con un commit o anularlas con un rollback. En cambio con el tipo InnoDB sí se permiten validaciones y anulaciones de transacciones. Por otro lado, al ejecutar estas consultas SQL en MyISAM, si se produce algún corte en la conexión y las consultas no se han ejecutado completamente, puede que queden datos inconsistentes. Por ejemplo, si ejecutamos esta consulta:

Código:
update empleados set sueldo = sueldo - 100 where sueldo > 10000;


Si se pruduce algún corte en la conexión mientras se ejecuta esta consulta SQL y utilizamos el tipo MyISAM quedarán sólo parte de los registros actualizados y no sabremos qué registros no se han actualizado. En cambio, utilizando InnoDB, si se produce un corte mientras se ejecuta la consulta SQL no se aplicarán los cambios y podremos volver a ejecutarla, es decir, garantiza que una transacción se ejecute íntegramente, de lo contrario la anula.

Para iniciar una transacción se utiliza el comando SQL:

Código:
begin


Para validarla se utiliza el comando:

Código:
commit


Para anularla se utiliza el comando:

Código:
rollback



Por otro lado, MyISAM no permite integridad referencial (uso de claves foráneas para "enlazar" varias tablas), en cambio InnoDB sí permite este tipo de relaciones.

InnoDB es más eficiente que MyISAM en cuanto a tiempos de respuesta para operaciones habituales, tales como INSERT, UPDATE, etc.

En cuanto al almacenamiento físico, InnoDB utiliza un único fichero mientras que MyISAM utiliza tres ficheros.
MensajePublicado:
Mie Sep 06, 2006 5:53 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A