Hibernate_事务管理

本文解析了Hibernate中如何正确地保存Customer对象到数据库的过程,并强调了显式调用Transaction提交指令的重要性。

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

 

转载于:https://www.cnblogs.com/rocker-pg/p/8231829.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值