Retour en arrière

Table des matières

Résumez avec :

El rollback es un término utilizado en informática, especialmente en el contexto de bases de datos y sistemas de gestión de transacciones, que se refiere a la acción de revertir un conjunto de operaciones a un estado anterior. Se realiza para asegurar la integridad y consistencia de los datos en caso de que ocurra un error, fallo o cualquier condición que requiera que las operaciones se deshagan.

Si ocurre un error durante una transacción, el rollback permite revertir todas las operaciones realizadas hasta ese punto para eliminar dicho error y mantener la coherencia original en los datos.

Características del rollback

Algunas características clave del rollback incluyen:

  • Atomicidad: El rollback garantiza que las transacciones sean atómicas, es decir, o se completan todas las operaciones dentro de una transacción o ninguna lo hace.
  • Consistencia: Asegura que el sistema regrese a un estado consistente después de una transacción fallida, evitando que los datos se corrompan.
  • Aislamiento: Los efectos de una transacción no son visibles para otras transacciones hasta que la transacción se complete. Si se hace un rollback, los cambios realizados en esa transacción no serán visibles para otras transacciones en curso.
  • Durabilidad: Aunque el rollback en sí deshace los cambios, el proceso de realizar un rollback está diseñado para ser duradero, de forma que los cambios no se apliquen y el sistema regrese a un estado seguro y coherente.

Aplicaciones del rollback

El rollback encuentra las siguientes aplicaciones:

  • Sistema financiero: El rollback es la herramienta que permite que una transacción sea atómica. Si ocurre un error durante la ejecución de una transacción bancaria, mediante el rollback podemos revertir todos los cambios que se han hecho hasta ese momento. 
  • Bases de données: En sistemas de bases de datos relacionales, el rollback es una operación esencial para manejar transacciones fallidas. Por ejemplo, si una transacción que involucra múltiples operaciones de inserción, actualización o eliminación falla a mitad de camino, el sistema puede revertir todas las operaciones realizadas hasta ese punto.
  • Sistemas de control de versiones: En el desarrollo de software, los sistemas de control de versiones como Git permiten realizar rollbacks para deshacer cambios a un estado previo del código.
  • Actualización de software: En la gestión de actualizaciones de sistemas y aplicaciones, el rollback permite revertir una actualización fallida a una versión anterior que funcionaba correctamente.

Ejemplo de sentencia rollback en SQL

Supongamos que tenemos una base de datos con dos tablas simples: clientes y transacciones. Queremos actualizar el saldo de un cliente y registrar una transacción. Sin embargo, si algo sale mal durante el proceso, necesitamos revertir todos los cambios realizados.

Estructura de las tablas

CREATE TABLE clientes (

    cliente_id INT PRIMARY KEY,

    nombre VARCHAR(100),

    saldo DECIMAL(10, 2)

);

CREATE TABLE transacciones (

    transaccion_id INT PRIMARY KEY,

    cliente_id INT,

    monto DECIMAL(10, 2),

    fecha DATE

);

  1. Iniciamos la transacción

BEGIN TRANSACTION;

  1. Realizamos una operación

— Supongamos que el cliente con ID 1 hace un depósito de 200

UPDATE clientes

SET saldo = saldo + 200

WHERE cliente_id = 1;

— Insertamos el registro de la transacción

INSERT INTO transacciones (transaccion_id, cliente_id, monto, fecha)

VALUES (1, 1, 200, GETDATE());

  1. Cometemos un error y hacemos rollback

IF @@ERROR != 0

BEGIN

    — Si ocurre un error, revertimos todas las operaciones

    ROLLBACK TRANSACTION;

    PRINT ‘Transacción fallida, cambios revertidos.’;

END

ELSE

BEGIN

    — Si no hay errores, confirmamos la transacción

    COMMIT TRANSACTION;

    PRINT ‘Transacción completada exitosamente.’;

END

Partager en :

Articles connexes

Évolutivité

L'évolutivité désigne la capacité d'un système à gérer une augmentation de la charge de travail, que ce soit en termes d'utilisateurs, de processus ou de données, sans perte de performance ou d'efficacité. Dans le contexte de l'informatique et de la

Bytecode

Le bytecode est un concept fondamental en informatique et en programmation, qui désigne une représentation intermédiaire d'un code de haut niveau, conçu pour être exécuté par une machine virtuelle ou un interprète. Le terme vient de l'anglais

Immutabilité

L'immutabilité fait référence à l'incapacité d'un objet ou d'une entité à changer ou à être modifié une fois qu'il a été créé ou défini. Dans le contexte de la programmation, les données immuables ne peuvent pas être modifiées une fois qu'elles sont créées. En d'autres termes, les données immuables ne peuvent pas être modifiées une fois qu'elles ont été créées,

ZTNA

ZTNA, ou Zero Trust Network Access, est une approche de la cybersécurité qui met en œuvre la philosophie «ne jamais faire confiance, toujours vérifier». Contrairement aux méthodes traditionnelles qui supposent que les utilisateurs et les appareils du réseau sont dignes de confiance.

Retour en haut