arrow left
Back to Developer Education

    Transaction management in a database

    Transaction management in a database

    A transaction is a logical unit of work performed on a database. They are logically ordered units of work completed by the end-user or an application. <!--more--> A transaction is made up of one or more database modifications. Creating, updating, or deleting a record from a table, for example. To preserve data integrity and address database issues, it's critical to keep track of these transactions. We can bundle SQL queries together and run them as a single transaction

    Prerequisites

    To follow through with this tutorial you need to know basic SQL(structured query language) and understand how to create a database.

    Transaction states

    There are various database transaction states as follows.

    1. Active state - this is the state in which a transaction execution process begins. Operations such as read or write are performed on the database.
    2. Partially committed - means that a transaction is only partially committed once it has been completed.
    3. Committed stage - After a transaction execution is completed successfully the transaction is in a committed state. All changes made to the database are permanently documented.
    4. Failed state - If a transaction is aborted while in the active state, or if one of the checks fails, the transaction is in the failed state.
    5. Terminated state - This state happens once the transaction leaving the system cannot be restarted once again.

    Transaction properties

    There are four main properties of a transaction represented in the acronym ACID. This referrs to Atomicity, Consistency, Isolation, and Durability.

    1. Atomicity - A transaction cannot be subdivided and can only be executed as a whole and is treated as an atomic unit. It is either all the operations are carried out or none are performed.
    2. Consistency - After any transaction is carried out in a database it should remain consistent. No transaction should affect the data residing in the database adversely.
    3. Isolation - When several transactions need to be conducted in a database at the same time, each transaction is treated as if it were a single transaction. As a result, the completion of a single transaction should have no bearing on the completion of additional transactions.
    4. Durability - From durable, all changes made must be permanent such that once the transaction is committed the effects of the transaction cannot be reversed. In case of system failure or unexpected shutdown and changes made by a complete transaction are not written to the disk, during restart the changes should be remembered and restored.

    Creating a database and a table

    We need to create a database with a table in which to execute our transaction commands. Here is the program to create a table;

    CREATE DATABASE Megacollege;
    CREATE TABLE STUDENTS(Id integer PRIMARY KEY, Name text, Regno varchar, Course text, Fees integer);
    
    
    INSERT INTO STUDENTS VALUES(1,'John', 'V20/680', 'Education', 40000);
    INSERT INTO STUDENTS VALUES(2,'Ahmed', 'G4/270', 'Computer Science',50000);
    INSERT INTO STUDENTS VALUES(3,'Ian', 'A43/476', 'Engineering', 62500);
    INSERT INTO STUDENTS VALUES(4,'Jane', 'A19/520', 'IT', 41200);
    INSERT INTO STUDENTS VALUES(5,'Robert','P62/491', 'Nursing',43700);
    INSERT INTO STUDENTS VALUES(6,'Hellen', 'V20/470', 'Education', 22000);
    INSERT INTO STUDENTS VALUES(7,'Joan','P62/801', 'Nursing',18000);
    BEGIN TRANSACTION;
    COMMIT;
    
    
    SELECT * FROM STUDENTS;
    

    Below is the output of the program.

    IDNAMEREG NOCOURSEFEES
    1JOHNV20/630Education40000
    2AHMEDG4/270Computer science50000
    3IANA43/476Engineering62500
    4JANEA19/520IT41200
    5ROBERTP62/491Nursing43700
    6HELLENV20/470Education22000
    7JOANP62/801Nursing18000

    Transactional control commands

    The Data Manipulation Language (DML) instructions are utilized with transactional commands such as INSERT, UPDATE, and DELETE. These commands cannot be used with the Data Definition Language because they are automatically committed to the database. Below are the transaction commands;

    1. COMMIT - Saves the changes done against the database.
    2. ROLLBACK - Redoes the changes done before being committed to the database.
    3. SAVEPOINT - saves a point in a transaction on which to carry out a rollback.
    4. SET TRANSACTION - Gives a name to a transaction.

    COMMIT command

    The COMMIT command saves changes made to a database as part of a transaction. The COMMIT command preserves all database transactions since the previous COMMIT or ROLLBACK command. The syntax of the COMMIT command;

    BEGIN TRANSACTION;
    COMMIT
    

    We can delete the records from the table that have fees=40000 and commit the changes in the database.

    BEGIN TRANSACTION;
    DELETE FROM STUDENTS
    WHERE FEES = 40000;
    COMMIT;
    

    This command will delete the row from the table which has fees equal to 40000 and save the changes to the database. When this command is executed the results are as follows;

    IDNAMEREG NOCOURSEFEES
    2AHMEDG4/270Computer science50000
    3IANA43/476Engineering62500
    4JANEA19/520IT41200
    5ROBERTP62/491Nursing43700
    6HELLENV20/470Education22000
    7JOANP62/801Nursing18000

    The first row is deleted and the results saved.

    ROLLBACK command

    The ROLLBACK command can only be used to undo transactions from the last ROLLBACK or COMMIT command issued. The ROLLBACK command syntax is as follows;

    BEGIN TRANSACTION;
    ROLLBACK;
    

    Consider deleting a record from the table where fees =40000 and ROLLBACK the changes;

    BEGIN TRANSACTION;
    DELETE FROM STUDENTS
    WHERE FEES = 40000;
    ROLLBACK;
    

    Executing the rollback command the results are as follows;

    IDNAMEREG NOCOURSEFEES
    1JOHNV20/630Education40000
    2AHMEDG4/270Computer science50000
    3IANA43/476Engineering62500
    4JANEA19/520IT41200
    5ROBERTP62/491Nursing43700
    6HELLENV20/470Education22000
    7JOANP62/801Nursing18000

    The delete operation will not change the records of the database therefore the results will be the same and the database remains unchanged.

    SAVEPOINT command

    This command rolls back a transaction to a point in the database without having to roll back the entire transaction. The SAVEPOINT command syntax;

    BEGIN TRANSACTION;
    SAVEPOINT SAVEPOINT_NAME;
    

    Unlike the ROLLBACK command, which reverses a set of transactions, the SAVEPOINT command just creates a SAVEPOINT among all transaction statements. Rolling back to a SAVEPOINT;

    BEGIN TRANSACTION;
    ROLLBACK TO SAVEPOINT_NAME;
    

    We can delete three records from the STUDENTS table. We create a SAVEPOINT before each delete, this enables us to ROLLBACK to any SAVEPOINT any time to get back to the original state of the record.

    BEGIN TRANSACTION;
    SAVEPOINT SP1;
    
    DELETE FROM STUDENTS WHERE ID = 1;
    
    SAVEPOINT SP2;
    
    DELETE FROM STUDENTS WHERE ID= 2;
    
    SAVEPOINT SP3;
    
    DELETE FROM STUDENTS WHERE ID= 3;
    

    After executing the savepoint command, we have the results as:

    IDNAMEREG NOCOURSEFEES
    4JANEA19/520IT41200
    5ROBERTP62/491Nursing43700
    6HELLENV20/470Education22000
    7JOANP62/801Nursing18000

    We have deleted from the table where id 1,2 and 3 exist but with savepoints SP1, SP2 and SP3 respectively. We can now rollback to any point using the savepoints.

    ROLLBACK TO SP2;
    
    IDNAMEREG NOCOURSEFEES
    2AHMEDG4/270Computer science50000
    3IANA43/476Engineering62500
    4JANEA19/520IT41200
    5ROBERTP62/491Nursing43700
    6HELLENV20/470Education22000
    7JOANP62/801Nursing18000

    The rollback command applies to the operations that happened after the savepoint SP2 and since the savepoint SP1 had initially been executed before SP2 it cannot be rolled back

    RELEASE SAVEPOINT command

    This command is used to delete a SAVEPOINT created. The RELEASE SAVEPOINT command syntax;

    BEGIN TRANSACTION;
    RELEASE SAVEPOINT savepoint_name;
    

    The ROLLBACK command cannot reverse transactions because the last SAVEPOINT command has been released.

    SET TRANSACTION command

    This command is used to initiate a database transaction. It specifies the characteristics of the transaction following. It specifies a transaction to either be read-only or read-write. The SET TRANSACTION syntax;

    BEGIN TRANSACTION;
    SET TRANSACTION [READ WRITE | READ ONLY];
    

    Conclusion

    With that, you are able to carry out transactions in the database and work with your database. You can also to gain access to your data in case of an unintentional delete. You can try some more examples with your own database for better understanding.

    Happy coding!


    Peer Review Contributions by: Adrian Murage

    Published on: Jul 29, 2021
    Updated on: Jul 15, 2024
    CTA

    Cloudzilla is FREE for React and Node.js projects

    Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
    Get Started for Free