我的java项目中spring事务总是出问题?

我的项目用的是spring4.1.6hibernate4.3.8我的SessionFactory是这么配置的:<beanid="sessionFactory"class=... 我的项目用的是spring 4.1.6 hibernate 4.3.8 我的SessionFactory是这么配置的: <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="hibernateProperties"> <props> <prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop> <prop key="current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext</prop> <prop key="hibernate.query.factory_class">org.hibernate.hql.internal.ast.ASTQueryTranslatorFactory</prop> <prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop> <prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop> <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</prop> </props> </property> <property name="mappingLocations"> <list> <value>classpath*:com/iresearch/demo/entity/*.hbm.xml</value> </list> </property> </bean>这个是TransactionManager的配置 <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> 这是事务的配置: <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="get*" read-only="true" /> <tx:method name="count*" read-only="true" /> <tx:method name="find*" read-only="true" /> <tx:method name="list*" read-only="true" /> <tx:method name="*" read-only="false" propagation="REQUIRED" /> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="txPointcut" expression="execution(* com.iresearch..*.*(..))" /> <aop:advisor pointcut-ref="txPointcut" advice-ref="txAdvice" /> </aop:config>我的包结构是这样的com.iresearch.cloud.entity/dao/service/controller dao层是数据交互层 service是业务层对dao层进行调用我的dao中多数用了SessionFactory的getCurrentSession方法获取session 以及用了hibernateTemplate 在进行单元测试都正常 一旦进入web环境 就会出现org.hibernate.HibernateException: Could not obtain transaction-synchronized Session for current thread的异常 我在spring mvc的配置文件中加入拦截器OpenSessionInViewInterceptor这个问题就不出现了 但会出现org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.这个问题看起来我的问题是方法没有加上事务造成session的flushmode全是manual 但是我事务配的没错啊 我换了好几种事务配置方式就是execution表达式换了好几个 都是这样的问题怎么回事啊? 展开
 我来答
疯子的憧憬林林
2016-06-23 · TA获得超过389个赞
知道小有建树答主
回答量:425
采纳率:50%
帮助的人:218万
展开全部
最近在项目的时候碰到pring事务不起作用的情况,后来解决了,这里我汇总下:

1、首先使用如下代码 确认你的bean 是代理对象吗?
必须是Spring定义(通过XML或注解定义都可以)的Bean才接受事务。
直接new出来的对象添加事务是不起作用的。
可以通过以下方式判断是否是代理对象:

AopUtils.isAopProxy(Object object)
AopUtils.isCglibProxy(Object object) //cglib
AopUtils.isJdkDynamicProxy(Object object) //jdk动态代理

2、入口函数必须是public,否则事务不起作用。这一点由Spring的AOP特性决定的。

3、切入点配置错误。
<!-- 使用annotation注解方式配置事务 -->
<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>
<!--使用切面方式配置事务-->
<tx:advice id="txadvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" isolation="READ_COMMITTED" propagation="REQUIRED" rollback-for="java.lang.Exception" />
</tx:attributes>
</tx:advice>

<aop:config>
<aop:pointcut id="pointcut" expression="execution(* com.tyyd..*Service.do*(..))"/>
<aop:advisor advice-ref="txadvice" pointcut-ref="pointcut"/>
</aop:config>

4、如果你使用了springmvc,可能是context:component-scan重复扫描引起的:

5、如使用mysql且引擎是MyISAM造成的(因为不支持事务),改成InnoDB即可。
追问
我看了一下 5肯定不是问题原因 都是innoDB 4我只在spring mvc里扫描注解 不存在重复扫描 3貌似我配置没错误 2没看懂 我所有dao和service的方法都是public的 1三个方法参数传入service对象全是false
风风风姬姬姬
2018-04-08 · TA获得超过8263个赞
知道小有建树答主
回答量:19
采纳率:100%
帮助的人:3030
展开全部

1、首先使用如下代码 确认你的bean 是代理对象吗?

必须是Spring定义(通过XML或注解定义都可以)的Bean才接受事务。

直接new出来的对象添加事务是不起作用的。

可以通过以下方式判断是否是代理对象:

AopUtils.isAopProxy(Object object)

AopUtils.isCglibProxy(Object object) //cglib

AopUtils.isJdkDynamicProxy(Object object) //jdk动态代理

2、入口函数必须是public,否则事务不起作用。这一点由Spring的AOP特性决定的。

3、切入点配置错误。

<!-- 使用annotation注解方式配置事务 -->

<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>

<!--使用切面方式配置事务-->

<tx:advice id="txadvice" transaction-manager="transactionManager">

<tx:attributes>

<tx:method name="*" isolation="READ_COMMITTED" propagation="REQUIRED" rollback-for="java.lang.Exception" />

</tx:attributes>

</tx:advice>

<aop:config>

<aop:pointcut id="pointcut" expression="execution(* com.tyyd..*Service.do*(..))"/>

<aop:advisor advice-ref="txadvice" pointcut-ref="pointcut"/>

</aop:config>

4、如果你使用了springmvc,可能是context:component-scan重复扫描引起的:

5、如使用mysql且引擎是MyISAM造成的(因为不支持事务),改成InnoDB即可。

org.springframework.transaction.UnexpectedRollbackException: Transaction rolled back because it has been marked as rollback-only

检查方法都是查询都没有异常,搜索百度了很多资料还是不解。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式