Python- Performing Transactions

Transactions ensure the data consistency of the database. We have to make sure that more than one applications must not modify the records while performing the database operations. The transactions have the following properties.

  1. Atomicity
    Either the transaction completes, or nothing happens. If a transaction contains 4 queries then all these queries must be executed, or none of them must be executed.
  2. Consistency
    The database must be consistent before the transaction starts and the database must also be consistent after the transaction is completed.
  3. Isolation
    Intermediate results of a transaction are not visible outside the current transaction.
  4. Durability
    Once a transaction was committed, the effects are persistent, even after a system failure.

Python commit() method

Python provides the commit() method which ensures the changes made to

the database consistently take place.

The syntax to use the commit() method is given below.

  1. conn.commit() #conn is the connection object   

All the operations that modify the records of the database do not take place until the commit() is called.


Python rollback() method

The rollback() method is used to revert the changes that are done to the database. This method is useful in the sense that, if some error occurs during the database operations, we can rollback that transaction to maintain the database consistency.

The syntax to use the rollback() is given below.

  1. Conn.rollback()  

Closing the connection

We need to close the database connection once we have done all the operations regarding the database. Python provides the close() method. The syntax to use the close() method is given below.

  1. conn.close()   

In the following example, we are deleting all the employees who are working for the CS department.

Example

  1. import mysql.connector  
  2.   
  3. #Create the connection object   
  4. myconn = mysql.connector.connect(host = "localhost", user = "root",passwd = "google",database = "PythonDB")  
  5.   
  6. #creating the cursor object  
  7. cur = myconn.cursor()  
  8.   
  9. try:  
  10.     cur.execute("delete from Employee where Dept_id = 201")  
  11.     myconn.commit()  
  12.     print("Deleted !")  
  13. except:  
  14.     print("Can?t delete !")  
  15.     myconn.rollback()  
  16.   
  17. myconn.close()  

Output:

Deleted !


;