Skip to content

Transactions in Hibernate

Picture this: You're at a cafe, and you order a coffee. Now, imagine that coffee order as a transaction. In Hibernate, a transaction is like a wrapper around all the actions you want to perform on your database. Whether it's adding new data, updating existing records, or deleting stuff, Hibernate makes sure it happens seamlessly, just like your coffee order being fulfilled without a hitch.

Now, let's talk about ACID. No, not the stuff you find in batteries, but rather a set of principles that ensure database transactions are reliable and consistent. Think of ACID as the trusty recipe for your favorite dish. Here's what each letter stands for:

Atomicity: This means that a transaction is like a single unit. It either happens completely or not at all. Just like when you order a combo meal – you get all the items together, not one by one.

Consistency: Your database should always be in a valid state, even if something goes wrong during a transaction. Like a well-trained chef, Hibernate ensures that your data remains consistent, no matter what.

Isolation: Imagine you're cooking in a busy kitchen. Isolation ensures that each transaction is like a chef working in their own corner, without interfering with others. So, even if multiple transactions are happening simultaneously, they won't step on each other's toes.

Durability: Once a transaction is complete, its changes are permanent, even in the face of power outages or system crashes. It's like when you save a document on your computer – even if it shuts down unexpectedly, your changes are still there when you reboot.


First, make sure you have Hibernate set up in your project along with your database configuration. Now, let's create a class to demonstrate transactions:

import org.hibernate.Session;
import org.hibernate.Transaction;

public class TransactionDemo {

    public static void main(String[] args) {
        // Set up Hibernate session
        Session session = HibernateUtil.getSessionFactory().openSession();
        Transaction transaction = null;

        try {
            // Begin transaction
            transaction = session.beginTransaction();

            // Perform database operations
            // Let's say we're adding a new record to a 'User' table
            User newUser = new User("John Doe", "");

            // Commit transaction
            System.out.println("Transaction committed successfully!");
        } catch (Exception e) {
            // Roll back transaction if there's an exception
            if (transaction != null) {
        } finally {
            // Close the session

In this code:

  • We start by setting up a Hibernate session and beginning a transaction.
  • Within the transaction, we perform some database operations, such as adding a new user to the database.
  • If any exception occurs during the transaction, we roll back the changes to maintain consistency.
  • Finally, we commit the transaction to make the changes permanent in the database.

Now, let's connect this to the concept of ACID properties:

  • Atomicity: The entire block of code within the try block is treated as a single unit. If any operation fails (e.g., saving the user), the entire transaction is rolled back (transaction.rollback()), ensuring that the database remains in a consistent state.

  • Consistency: Hibernate ensures that the database remains in a valid state at all times. Even if an exception occurs and the transaction is rolled back, the database will not be left in an inconsistent state.

  • Isolation: Each transaction is independent of others. Even if multiple transactions are being executed simultaneously, they do not interfere with each other's data. Hibernate manages this isolation behind the scenes.

  • Durability: Once the transaction is committed (transaction.commit()), the changes made to the database are permanent and will persist even if the application crashes or the system loses power.

This example demonstrates how Hibernate handles transactions and adheres to the ACID properties, providing reliability and consistency in database operations.

Waytojava is designed to make learning easier. We simplify examples for better understanding. We regularly check tutorials, references, and examples to correct errors, but it's important to remember that humans can make mistakes.