Friday, July 22, 2011

Incorrect Order of SQL execution within a Spring Hibernate Transaction

Recently I faced a strange issue when trying to insert proper data into table ,it was halting with Unique key Constraint Exception.In a transaction I had to read a record and update the Unique Key fields and in the next step insert a record .The record inserted should have the same Unique Key values as the record read from the table.The sequence was a simple read,update and insert a new record.Was baffled when this sequence continuous threw a Unique Key Constraint.When I removed the UK constraint from the table,the records were updated and inserted as required.

On checking on the hibernate log found that the insert was fired before the update .I tried to disable the Spring transaction and then the order of execution was correct.
Looks like the order of SQl execution is not guaranteed within a transaction.To solve this issue one of the following needs to be done after the update and before the insert
1.call hibernateTemplate.flush() or
2.call hibernateTemplate.refresh() or
3.again read the record from table ,this internally calls the flush.

1 comment:

  1. hi Asha,

    I also had the same issue when trying to do query, update and insert inside the same transaction. But upon further readings i could understand hibernate caches its the query and it will do the actual database operations only when we commit the transaction. HibernateTemplate.flush makes this cache clear and execute it immediately to the database. But it wont commit to the database, so even if some exceptions happens after the flush, it can be safely rolled back from the database.

    ReplyDelete