今天学习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();