Hibernate事务的示例分析

小编给大家分享一下Hibernate事务的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

Hibernate是JDBC的轻量级封装,本身并不具备事务管理能力。在事务管理层,Hibernate将其委托给底层的JDBC或者JTA,以实现事务管理和调度功能。

Hibernate事务处理机制基于JDBC Transaction.我们也可以通过配置文件设定采用JTA作为事务管理实现:

<hibernate-configuration> <session-factory> ……  <property name="hibernate.transaction.factory_class"> net.sf.hibernate.transaction.JTATransactionFactory  <!--net.sf.hibernate.transaction.JDBCTransactionFactory--> </property> ……  </session-factory> </hibernate-configuration>

基于JDBC的事务管理将事务管理委托给JDBC 进行处理无疑是最简单的实现方式,Hibernate事务对于JDBC事务的封装也极为简单。
我们来看下面这段代码:

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),下面的代码将不会对数据库产生任何效果:

session = sessionFactory.openSession();  session.save(user);  session.close();

这实际上相当于 JDBC Connection的AutoCommit属性被设为false,执行了若干JDBC操作之后,没有调用commit操作即将Connection关闭。如果要使代码真正作用到数据库,我们必须显式的调用Transaction指令:

session = sessionFactory.openSession();  Transaction tx = session.beginTransaction();  session.save(user);  tx.commit();  session.close();

以上是“Hibernate事务的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注蜗牛博客行业资讯频道!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论电报频道链接