PL / SQL - Transaktionen

In diesem Kapitel werden die Transaktionen in PL / SQL erläutert. Eine Datenbanktransactionist eine atomare Arbeitseinheit, die aus einer oder mehreren verwandten SQL-Anweisungen bestehen kann. Es wird als atomar bezeichnet, da die durch die SQL-Anweisungen, die eine Transaktion darstellen, vorgenommenen Datenbankänderungen gemeinsam entweder festgeschrieben, dh dauerhaft in der Datenbank gespeichert oder aus der Datenbank zurückgesetzt (rückgängig gemacht) werden können.

Eine erfolgreich ausgeführte SQL-Anweisung und eine festgeschriebene Transaktion sind nicht identisch. Selbst wenn eine SQL-Anweisung erfolgreich ausgeführt wird, kann sie rückgängig gemacht werden, sofern die Transaktion, die die Anweisung enthält, nicht festgeschrieben wird, und alle von den Anweisungen vorgenommenen Änderungen können rückgängig gemacht werden.

Starten und Beenden einer Transaktion

Eine Transaktion hat eine beginning und ein end. Eine Transaktion beginnt, wenn eines der folgenden Ereignisse stattfindet:

  • Die erste SQL-Anweisung wird ausgeführt, nachdem eine Verbindung zur Datenbank hergestellt wurde.

  • Bei jeder neuen SQL-Anweisung, die nach Abschluss einer Transaktion ausgegeben wird.

Eine Transaktion endet, wenn eines der folgenden Ereignisse stattfindet:

  • EIN COMMIT oder ein ROLLBACK Erklärung wird ausgegeben.

  • EIN DDL Aussage, wie CREATE TABLEErklärung, wird ausgestellt; denn in diesem Fall wird automatisch ein COMMIT ausgeführt.

  • EIN DCL Aussage, wie a GRANTErklärung, wird ausgestellt; denn in diesem Fall wird automatisch ein COMMIT ausgeführt.

  • Benutzer trennt sich von der Datenbank.

  • Benutzer beendet von SQL*PLUS durch die Ausgabe der EXIT Befehl wird automatisch ein COMMIT ausgeführt.

  • SQL * Plus wird abnormal beendet, a ROLLBACK wird automatisch durchgeführt.

  • EIN DMLAnweisung schlägt fehl; In diesem Fall wird automatisch ein ROLLBACK ausgeführt, um diese DML-Anweisung rückgängig zu machen.

Festschreiben einer Transaktion

Eine Transaktion wird durch Ausgabe des SQL-Befehls COMMIT permanent gemacht. Die allgemeine Syntax für den Befehl COMMIT lautet -

COMMIT;

Zum Beispiel,

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 ); 

COMMIT;

Rollback von Transaktionen

Änderungen, die ohne COMMIT an der Datenbank vorgenommen wurden, können mit dem Befehl ROLLBACK rückgängig gemacht werden.

Die allgemeine Syntax für den Befehl ROLLBACK lautet -

ROLLBACK [TO SAVEPOINT < savepoint_name>];

Wenn eine Transaktion aufgrund einer beispiellosen Situation wie einem Systemausfall abgebrochen wird, wird die gesamte Transaktion seit einem Commit automatisch zurückgesetzt. Wenn Sie nicht verwendensavepointVerwenden Sie dann einfach die folgende Anweisung, um alle Änderungen rückgängig zu machen:

ROLLBACK;

Sicherungspunkte

Sicherungspunkte sind eine Art Markierung, mit deren Hilfe eine lange Transaktion in kleinere Einheiten aufgeteilt werden kann, indem einige Prüfpunkte festgelegt werden. Durch Festlegen von Sicherungspunkten innerhalb einer langen Transaktion können Sie bei Bedarf einen Rollback auf einen Prüfpunkt durchführen. Dies erfolgt durch Ausgabe desSAVEPOINT Befehl.

Die allgemeine Syntax für den Befehl SAVEPOINT lautet -

SAVEPOINT < savepoint_name >;

Zum Beispiel

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Rajnish', 27, 'HP', 9500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (8, 'Riddhi', 21, 'WB', 4500.00 ); 
SAVEPOINT sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000; 
ROLLBACK TO sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 7; 
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 8; 

COMMIT;

ROLLBACK TO sav1 - Diese Anweisung setzt alle Änderungen bis zu dem Punkt zurück, an dem Sie savepoint sav1 markiert haben.

Danach beginnen die neuen Änderungen, die Sie vornehmen.

Automatische Transaktionssteuerung

Um a COMMIT automatisch wann immer ein INSERT, UPDATE oder DELETE Befehl ausgeführt wird, können Sie die einstellen AUTOCOMMIT Umgebungsvariable als -

SET AUTOCOMMIT ON;

Sie können den Auto-Commit-Modus mit dem folgenden Befehl deaktivieren:

SET AUTOCOMMIT OFF;