Java 在抛出异常后回滚事务
当我在服务方法中抛出异常时,我希望服务上的事务性注释将回滚保存操作,但它不起作用 这是我的服务:Java 在抛出异常后回滚事务,java,spring,spring-data-jpa,spring-transactions,Java,Spring,Spring Data Jpa,Spring Transactions,当我在服务方法中抛出异常时,我希望服务上的事务性注释将回滚保存操作,但它不起作用 这是我的服务: @Service @Transactional(value = "transactionManager", rollbackFor = Exception.class) public class OrderServiceImp implements OrderService { @Autowired private OrderRepository or
@Service
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
public class OrderServiceImp implements OrderService {
@Autowired
private OrderRepository orderRepository;
@Override
public void doSomeStaff(Long orderId) {
Order order = orderRepository.findOne(orderId);
orderRepository.save(order);
throw new NullPointerException("Test transaction exeption");
}
}
在data.xml中,我有下一个配置:
<tx:annotation-driven transaction-manager="transactionManager" />
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<jpa:repositories base-package="com.dmitro.repositories" entity-manager-factory-ref="entityManagerFactory" transaction-manager-ref="transactionManager"/>
在dispatcher-servlet.xml中,我声明了扫描:
<context:component-scan base-package="com.dmitro.service" />
我使用的是spring数据JPA1.8.0.RELEASE。请帮忙 尝试在OrderRepositoryImpl中抛出异常,看看它是否有效
public class OrderRepositoryImpl implements OrderRepository {
@Override
public void save() {
throw new SomeRunTimeException();
}
}
public class OrderServiceImp implements OrderService {
@Override
public void doSomeStaff(Long orderId) {
Order order = orderRepository.findOne(orderId);
orderRepository.save(order);
}
}
这就是罪魁祸首。您不应该为服务和存储库使用不同的事务管理器。要修复此问题,您需要将此处的transactionManagerForServiceLayer替换为transactionManager,然后回滚即可 数据源自动提交已打开(或为True)。关闭它(或为false)。问题在配置中,因为我在不同的spring上下文中声明了服务和事务管理器:事务管理器在根上下文中,服务在子dispatcher-servlet.xml上下文中 请发布spring配置的其余部分。您的服务是如何注册的?有关my configs中的内容和位置的更新信息。data.xml是否导入到dispatcher-servlet.xml中?OrderServiceImp在com.dmitro.service包中吗?为什么有两个事务管理器?Spring将回滚为该服务打开的事务。但是由于DAO使用不同的事务管理器,因此此时已经提交了为DAO打开的事务。Steve Hall的问题是正确的:为什么你有两个交易经理?
@Transactional(value = "transactionManagerForServiceLayer", rollbackFor = Exception.class)