Why do I need Transaction in Hibernate for read-only operations?
Does the following transaction put a lock in the DB?
Example code to fetch from DB:
Transaction tx = HibernateUtil.getCurrentSession().beginTransaction(); // why begin transaction?
//readonly operation here
tx.commit() // why tx.commit? I don't want to write anything
Can I use session.close() instead of tx.commit()?
Transactions for reading might look indeed strange and often people don’t mark methods for transactions in this case. But JDBC will create transaction anyway, it’s just it will be working in
autocommit=trueif different option wasn’t set explicitly. But there are practical reasons to mark transactions read-only:Impact on databases
Impact on ORM
Impact on architecture & clean code
There is no guarantee that your method doesn’t write into the database. If you mark method as
@Transactional(readonly=true), you’ll dictate whether it’s actually possible to write into DB in scope of this transaction. If your architecture is cumbersome and some team members may choose to put modification query where it’s not expected, this flag will point you to the problematic place.