Requerimientos

Páginas: 8 (1856 palabras) Publicado: 10 de noviembre de 2010
Transacciones en MySQL
Introducción al uso de las sentencias BEGIN, COMMIT y ROLLBACK para el manejo de transacciones en MySQL con el uso de tablas del tipo InnoDB.

Introducción
El servidor de bases de datos MySQL soporta distintos tipos de tablas, tales como ISAM, MyISAM, InnoDB, y DBD (Berkeley Database). De éstos, InnoDB es el tipo de tabla más importante (después del tipo predeterminado,MyISAM), y merece una atención especial.

Las tablas del tipo InnoDB están estructuradas de forma distinta que MyISAM, ya que se almacenan en un sólo archivo en lugar de tres, y sus principales características son que permite trabajar con transacciones, y definir reglas de integridad referencial.

El soporte de transacciones que provee MySQL no es algo nuevo en MySQL 4, ya que desde laversión 3.23 se podía hacer uso de tablas InnoDB, la única diferencia es que con la llegada de la versión 4.0 de MySQL, el soporte para este tipo de tablas es habilitado por default.

Las transacciones aportan una fiabilidad superior a las bases de datos. Si disponemos de una serie de consultas SQL que deben ejecutarse en conjunto, con el uso de transacciones podemos tener la certeza de que nunca nosquedaremos a medio camino de su ejecución. De hecho, podríamos decir que las transacciones aportan una característica de "deshacer" a las aplicaciones de bases de datos.

Para este fin, las tablas que soportan transacciones, como es el caso de InnoDB, son mucho más seguras y fáciles de recuperar si se produce algún fallo en el servidor, ya que las consultas se ejecutan o no en su totalidad. Porotra parte, las transacciones pueden hacer que las consultas tarden más tiempo en ejecutarse.

Seguramente alguna vez hemos escuchado hablar acerca de las transacciones, pero probablemente no entendemos bien lo que son, y como deben de ser usadas. La idea de este artículo es presentar algunos ejemplos para mostrar que no es nada complicado, y difícil de aprender.

En este artículo se asume quese cuenta ya con un servidor MySQL con soporte para el tipo de tablas InnoDB. En nuestro caso haremos uso de un servidor MySQL 4.013 ejecutándose en un sistema MSWindows.

Para asegurarnos que tenemos soporte para el tipo de tablas InnoDB podemos ejecutar la siguiente sentencia:

mysql> SHOW VARIABLES LIKE '%innodb%';
+---------------------------------+------------+
| Variable_name| Value |
+---------------------------------+------------+
| have_innodb | YES |
| innodb_additional_mem_pool_size | 1048576 |
| innodb_buffer_pool_size | 8388608 |
| innodb_data_file_path | ibdata:30M |
| innodb_data_home_dir | |
| innodb_force_recovery | 0 |
|innodb_thread_concurrency | 8 |
| innodb_fast_shutdown | ON |
| innodb_flush_method | |
| innodb_log_arch_dir | .\ |

....

La variable más importante es por supuesto have_innodb que tiene el valor YES.

En efecto, una de las principales características de las tablas del tipo InnoDB es que pueden trabajar con transacciones, osentencias SQL que son agrupadas como una sola. Un ejemplo típico de esto es una transacción bancaria. Por ejemplo, si una cantidad de dinero es transferida de la cuenta de una persona a otra, se requerirán por lo menos dos consultas:

UPDATE cuentas SET balance = balance - cantidad_transferida WHERE cliente = persona1;

UPDATE cuentas SET balance = balance + cantidad_transferida WHERE cliente =persona2;

Estas dos consultas deben trabajar bien, ¿pero qué sucede si ocurre algún imprevisto y "se cae" el sistema después de que se ejecuta la primer consulta, pero la segunda aún no se ha completado?. La persona1 tendrá una cantidad de dinero removida de su cuenta, y creerá que ha realizado su pago, sin embargo, la persona2 estará enfadada puesto que pensará que no se le ha depositado el...
Leer documento completo

Regístrate para leer el documento completo.

Estos documentos también te pueden resultar útiles

  • Requerimientos
  • Requerimientos
  • requerimientos
  • requerimientos
  • Requerimientos
  • Requerimientos
  • requerimiento
  • El Requerimiento

Conviértase en miembro formal de Buenas Tareas

INSCRÍBETE - ES GRATIS