Hibernate_事务管理

时间:2021-11-03 09:49:19

今天学习Hibernate,发现当我在执行下面操作时,不会对数据库产生任何效果,就是说Customer对象并不会保存到数据库中

Session session = HibernateUtils.openSession();
Customer customer = new Customer();
customer.setCust_name("哈哈");
session.save(customer);

我们来看下面这段代码:

session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
……
tx.commit();

从JDBC层面而言,上面的代码实际上对应着:

Connection dbconn = getConnection();
dbconn.setAutoCommit(false);
……
dbconn.commit();

就是这么简单,Hibernate并没有做更多的事情(实际上也没法做更多的事情),只是将这样的JDBC代码进行了封装而已。
这里要注意的是,在sessionFactory.openSession()中,hibernate会初始化数据库连接,与此同时,将其AutoCommit
设为关闭状态(false)。而其后,在Session.beginTransaction 方法中,Hibernate
会再次确认Connection 的AutoCommit 属性被设为关闭状态( 为了防止用户代码对session
的Connection.AutoCommit属性进行修改)。

这也就是说,我们一开始从SessionFactory获得的session,其自动提交属性就已经被关闭(AutoCommit=false),因此上面操作Customer的代码将不会对数据库产生任何效果。

如果要使代码真正作用到数据库,我们必须显式的调用Transaction指令:

Session session = HibernateUtils.openSession();

Transaction transaction = session.beginTransaction();

Customer customer = new Customer();
customer.setCust_name("哈哈");
session.save(customer); transaction.commit();