首页 > 代码库 > Hibernate和jdbc事务原理

Hibernate和jdbc事务原理

菜鸟就是菜鸟,不遇到问题还发现不了自己错在哪了...........


昨天遇到问题,(使用的springMVC和Hibernate,事务是配置的数据源 匹配方法名来加事务的),在几个service的方法之间嵌套使用时,发现修改数据数据库没变,我以为是几个service相互嵌套 事务加在了最外层 内层的不用加了就,只需要内层的向上抛出异常便可。到最后发现内层的方法中修改新增的地方修改不了。 仔细查找发现内层的service方法名 不是按照匹配的格式写的(save/del....)之类的,然后我手动加上@Transactional 事务标签,竟然好了.....
之前一直以为 加事务是为了出错时候事务回滚,没发现hibernate的事务不仅仅是回滚,还要事务的提交 !!并且在项目中一般是只有一层事务的,就是指的你程序的那一层控制。仔细搜了下原来如此:


  在Hibernate中, Session打开的时候,就会自动conn.setAutoCommit(false),不像一般的JDBC,默认都是true,所以你最后不写 commit也没有关系,由于Hibernate已经把AutoCommit给关掉了,所以用Hibernate的时候,你在程序中不写Transaction的话,数据库根本就没有反应。
conn.setAutoCommit(false) 这个方法中的参数如下:

true:sql命令的提交(commit)由驱动程序负责false:sql命令的提交由应用程序负责,程序必须调用commit或者rollback方法



Hibernate和jdbc事务原理