spring事务管理的控制问题

本文探讨了使用Spring和Hibernate进行数据库操作时如何确保事务一致性。特别是在执行多个更新操作时,如何保证所有操作要么全部成功,要么全部回滚。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[code]<bean id="transactionManager" class="org.springframework.orm.hibernate.HibernateTransactionManager">
<property name="sessionFactory"><ref local="sessionFactory"/></property>
</bean>

<bean id="userDao" class="hibernate.dao.Dao">
<property name="sessionFactory"><ref local="sessionFactory"/></property>
</bean>

<bean id="userDAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager"><ref local="transactionManager"/></property>
<property name="target"><ref local="userDao"/></property>
<property name="transactionAttributes">
<props>
<prop key="insert*">PROPAGATION_REQUIRED</prop>
<prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="query">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="update">PROPAGATION_REQUIRED</prop>
<prop key="execute">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>[/code]

用spring跟hibernate结合的方式,如果我在插入一条数据时,想往备份数据库的备份表也插入一条同样的记录
例如

[code]public void update()
{
//从上面的配置文件,得到两个userDaoProxy对象,
formalDaoProxy.update(bean);
backupDaoProxy.update(bean);
}[/code]

这样的话,由于正式表与备份表要保持数据一致性,所以,两个update其中一个失败, 另一个都要rollback , 但是这两个Dao, 分别由两个独立事务来自动管理的, commit或rollback都不能干预, 请问怎样可以用代码来控制其rollback?我找了很久都找不到.请教一下大家, 谢谢.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值