Мой работник базы данных реализован выше Hibernate. Если что-то идет не так, его методы должны откатить транзакцию и выдать SQLException
. Итак, мой вопрос: каков наилучший (т.е. самый чистый) способ обработки исключений Hibernate? В настоящее время все мои методы выглядят так же ужасно, как это:
public EntryUserHib addUser(final String username, final String pwdhash) throws SQLException{
try {
final Transaction ta = sess.beginTransaction();
try {
// Using Hibernate here
// "return" statement
} catch(final HibernateException ex) {
try {
ta.rollback();
} catch(final Exception ex1) {}
throw ex;
} finally {
if (!ta.wasRolledBack()) ta.commit();
}
} catch(final HibernateException ex) {
if (ex.getCause() != null) {
if (ex.getCause() instanceof SQLException) throw (SQLException)ex.getCause();
throw new SQLException(ex.getCause());
}
throw new SQLException(ex);
}
}