项目中使用了ibatis、hibernate时,怎么来控制事务

问题描述

现在的项目中使用了ibatis、hibernate然后在spring的配置文件里面配置<beanid="txManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><propertyname="dataSource"ref="dataSource"/></bean><beanid="hibernateTxManager"class="org.springframework.orm.hibernate3.HibernateTransactionManager"><propertyname="sessionFactory"ref="sessionFactory"/></bean>但是:<tx:annotation-driventransaction-manager="txManager"/>里面只能配置一个,这个可怎么办呢?1、如果配置如上的话(<tx:annotation-driventransaction-manager="hibernateTxManager"/>),则使用ibatis的得不到事务的保障?2、如果在一个方法中混合使用hibernate、ibatis,如何保证事务?请各位不吝赐教

解决方案

解决方案二:
没这样搞过,要么你就统一一下这个方法里面使用的框架吧,
解决方案三:
配置成这样就可以了。<!--声明式事务--><beanid="transactionManager"class="org.springframework.orm.hibernate3.HibernateTransactionManager"><propertyname="sessionFactory"ref="sessionFactory"/></bean><tx:adviceid="txAdvice"transaction-manager="transactionManager"><tx:attributes><!--根据实际需要对指定方法进行事务参数的指定--><tx:methodname="*"isolation="READ_COMMITTED"/><tx:methodname="find*"read-only="true"/></tx:attributes></tx:advice><aop:config><aop:advisoradvice-ref="txAdvice"pointcut="execution(*com.wlzx.service.*.*(..))"/></aop:config>

解决方案四:
一般事务是放在service层的,对于持久层,用ibatis还是hibernate,对spring来说,都是透明的,就像2楼的配置那样。当然也可以更细化一点,用注解在需要加事务的地方打上标记。
解决方案五:
引用2楼的回复:

配置成这样就可以了。XMLcode<!--声明式事务--><beanid="transactionManager"class="org.springframework.orm.hibernate3.HibernateTransactionManager"><propertyname="sessionFactory"ref="sessio……

如果使用注解的话,有没有什么好的方法呢?因为我们系统已经弄好了,方法名不好统一了已经但是我发现使用<tx:annotation-driventransaction-manager="txManager"/>的话heibernate的事务不起作用如果使用<tx:annotation-driventransaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
解决方案六:
引用3楼的回复:

一般事务是放在service层的,对于持久层,用ibatis还是hibernate,对spring来说,都是透明的,就像2楼的配置那样。当然也可以更细化一点,用注解在需要加事务的地方打上标记。

使用注解的话在applicationContext.xml里面应该怎么配置呢?但是我发现使用<tx:annotation-driventransaction-manager="txManager"/>的话heibernate的事务不起作用如果使用<tx:annotation-driventransaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
解决方案七:
使用hibernate来控制拦截当然你也可以手动控制connection
解决方案八:
引用6楼的回复:

使用hibernate来控制拦截当然你也可以手动控制connection

可不可以具体说一下
解决方案九:
我也遇到了同样的问题,请问楼主是怎么解决的呀,望不吝赐教呀。谢谢。
解决方案十:
我来转载个文章吧,楼主看看有没帮助http://stamen.iteye.com/blog/1441858序号混合数据访问技术框架事务管理器1Hibernate+SpringJDBC或iBatisorg.springframework.orm.hibernate3.HibernateTransactionManager2JPA+SpringJDBC或iBatisorg.springframework.orm.jpa.JpaTransactionManager3JDO+SpringJDBC或iBatisorg.springframework.orm.jdo.JdoTransactionManager
解决方案十一:
<?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPEbeansPUBLIC"-//SPRING//DTDBEAN//EN""http://www.springframework.org/dtd/spring-beans.dtd"><beans><beanid="dataSource"class="org.apache.commons.dbcp.BasicDataSource"><propertyname="driverClassName"value="oracle.jdbc.driver.OracleDriver"/><propertyname="url"value="jdbc:oracle:thin:@192.168.77.176:1521:数据库"/><propertyname="username"value="用户"/><propertyname="password"value="密码"/></bean><beanid="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><propertyname="locations"><list><value>classpath:SqlMapConfig.properties</value></list></property></bean><beanid="sqlMapClient"class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"><propertyname="configLocation"value="classpath:SqlMapConfig.xml"/><propertyname="dataSource"ref="dataSource"/></bean><beanid="testDAO"class="dao.TestDAO"><propertyname="sqlMapClient"ref="sqlMapClient"/></bean><beanname="testService"class="service.TestService"><propertyname="testDAO"ref="testDAO"/></bean><beanid="transactionManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><propertyname="dataSource"ref="dataSource"/></bean><beanid="transactionInterceptor"class="org.springframework.transaction.interceptor.TransactionInterceptor"><propertyname="transactionManager"ref="transactionManager"/><propertyname="transactionAttributes"><props><propkey="*">PROPAGATION_REQUIRED,-Exception</prop><propkey="find*">PROPAGATION_REQUIRED,readOnly</prop><propkey="query*">PROPAGATION_REQUIRED,readOnly</prop><propkey="get*">PROPAGATION_REQUIRED,readOnly</prop></props></property></bean><beanid="beanProxy"class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"><propertyname="beanNames"><list><value>testService</value></list></property><propertyname="interceptorNames"><list><value>transactionInterceptor</value></list></property></bean></beans>

解决方案十二:
这个问题,楼主解决了吗?

时间: 2024-10-06 11:10:05

项目中使用了ibatis、hibernate时,怎么来控制事务的相关文章

java项目中对象第二次创建时,第一个对象为什么还存在

问题描述 java项目中对象第二次创建时,第一个对象为什么还存在 可能我问题提的不太清楚,我举个例子 比如一个类 public class A{ private List list = new ArrayList(); public void add(){ list.add("abv"); } public void tell(){ System.out.print(list.size()); } } 在其他地方调用 A a = new A(); a.add(); Thread.sle

jquery在项目中做复选框时遇到的一些问题笔记_jquery

关于复选框 昨天在做一个复选框的时候,一开始以为应该挺简单的,想当然了一下,主要的功能就是点击一个按钮,比如是全部选中这个一个功能,然后下面的所有列表全部选中的效果. 后来在实践中还是遇到了很多的问题,注意在input的checkbox中,用普通的attr属性来判断是不可以的,因为checked的值是checked,只有用prop这个属性才能该改变!!!!见api文档,后来在百度中发现了这个在官方的api中就已经有说明了,附上jquery中一个prop的api地址http://api.jquer

asp.net中引用同一个项目中的类库 避免goToDefinition时不能到达真正的定义类_实用技巧

新建一个解决方案: Api 添加类库 APi.Data APi.Data 新建一个 Entity 复制代码 代码如下: public class Entity { private int id; public int Id { get { return id; } set { id = value; } } private string name; public string Name { get { return name; } set { name = value; } } } 添加类库 A

应用-SSH中Hibernate具体在项目中怎么用的

问题描述 SSH中Hibernate具体在项目中怎么用的 Hibernate 最新在学习Hibernate,但感觉学着有点力不从心,有人知道在项目中具体是怎么 应用的吗,或者说这个知识可以解决什么样的具体问题,求教.谢谢. 解决方案 第一:数据库连接不需要我们自己来管理,如打开和关闭. 第二:Hibernate对原来的SQL语句进行了封装,以前写很多SQL语句,现在你在保存的时候直接可以用 SAVE(对象)来实现了.(节省代码) 第三:原来是对表操作,现在是对对象操作,想法上是不是更好呢?都是对

ssh项目中hibernate查询时出问题

问题描述 ssh项目中hibernate查询时出问题 大神快来帮忙看看 解决方案 http://blog.csdn.net/merry3602/article/details/7063226 解决方案二: 报错SysAdmin未映射,重点是配置文件对不对. 首先检查你画线的地方路径写对了没有,其次要去检查SysAdmin.hbm.xml里面class标签的name属性值有没有打对,点路径有没有写对,最好把schema属性删除. 最后,看一下其他的.hbm.xml里有没有引用到SysAdmin的,

对于myeclipse中hibernate项目,当数据库设计发生变化时。。。

问题描述 对于myeclipse中hibernate项目,当数据库设计发生变化时... 我想请问一下当数据库的设计发生变化时(比如添加了某些列),怎样更新在myeclipse项目中使用hibernate产生的配置?或者只能自己改? 解决方案 有专门的生成各个文件的插件,只有model中添加了相应的字段,就会生成.不用插件的话就只能自己改了.

Java项目中使用Hibernate处理数据

数据|项目 对象-关系映射(O/R映射)是许多软件开发项目的常见需求.数据持久化过程中所涉及到的活动是非常乏味且易于出错的.如果考虑到不可避免的需求变化,我们就面临很大的麻烦:数据存储结构必须与源代码保持同步.再加上移植性问题,事情就变得非常复杂. 而Hibernate可以帮助我们轻松地在永久性存储介质中保存数据,而不需要在选择存储.安装或配置类型方面浪费太多精力.Hibernate允许我们存储任何类型的对象,因此,应用程序不需要知道其数据将使用Hibernate进行持久化.当然,这里提到的任何

spring-在Spring MVC,Spring,Hibernate整合项目中,jetty无法启动?

问题描述 在Spring MVC,Spring,Hibernate整合项目中,jetty无法启动? jetty启动时错误如下,显示servlet类找不到? 2016-03-22 21:04:50.227:WARN:oejuc.AbstractLifeCycle:FAILED o.e.j.w.WebAppContext{/,file:/F:/Project/FireGoBacker/Client/webapp/},F:ProjectFireGoBackerClientwebapp: java.la

项目中使用System.Threading.Timer对象时IIS释放Timer对象的问题

之前的一个项目中使用System.Threading.Timer对象时有没有遇到IIS释放Timer对象的问 题.说实话之前真没遇到过这个问题,就是说我之前定义的timer对象没有释放,运行正常, 回来后我就百度寻找这方面得信息,原来IIS在运行WebApp时对于非静态资源都是自动释放, 而我回头看了看之前写的Web程序,很幸运当时是这么写的: Global.asax文件 private static Timer time; //System.Threading; private static