草庐IT

Transactional

全部标签

java - 乐观锁的重试机制(spring data + JPA)

我们决定在我们的Web应用程序中使用乐观锁定以提高并发性,而不使用悲观锁定。我们现在正在寻找重试解决方案。我们希望对当前代码库的影响尽可能小。我们在网上看到的一种解决方案是使用带有注释的重试拦截器将方法标记为可重试。问题是我们想注释带有@Transactional注释的方法,但拦截器由于某种原因无法重试它们。(拦截器完美重试非事务方法。)所以:1)是否有任何对我们的代码影响最小的重试替代方案?2)是否有该解决方案的文档\教程?3)是否可以重试@Transactional注释的方法?干杯! 最佳答案 广告3.您可以使用SpringRe

java - 声明式事务 (@Transactional) 在 Spring 中不适用于 @Repository

我正在尝试使用Spring、JPA和嵌入式H2数据库制作简单的应用程序。最近我在声明式交易中遇到了这个奇怪的问题。如果我使用@Repository注释Autowiring我的DAO,他们就不会提交。更具体地说,我在刷新时遇到异常:javax.persistence.TransactionRequiredException:ExceptionDescription:Notransactioniscurrentlyactive这是我的设置:持久性.xmlorg.eclipse.persistence.jpa.PersistenceProviderfalse实体@Entity@Table(n

java - 事务的 Spring 自注入(inject)

在Spring中,由于AOP代理,您不能简单地从同一实例调用@Transactional方法。进行self注入(inject)并从self代理实例调用该方法会是个好主意吗?您看到任何缺点了吗? 最佳答案 完全没问题。此外还有一个Jiraticket使用@Autowired注释支持此功能。它在Spring4.3+版本中得到修复。然而,对于基于xml的配置或使用@Resource注释,它在早期版本中工作。您可以在这张工单下方看到讨论。@Transactional是one这个用例的:Particularlyinterestedin@Asy

java - Spring @Transactional注解: Self Invocation

我知道当从同一个类内部调用事务方法时,它不会在事务中运行。Spring为事务方法创建代理并将它们包装在try-catchblock中,并在发生异常时回滚。考虑以下场景:@TransactionalpublicvoidsaveAB(Aa,Bb){saveA(a);saveB(b);}@TransactionalpublicvoidsaveA(Aa){dao.saveA(a);}@TransactionalpublicvoidsaveB(Bb){dao.saveB(b);}假设saveAB被另一个对象调用并且在saveB中发生异常,所以saveA成功完成但saveB没有。据我所知,即使sa

java - JPA+Hibernate+@Transactional注解的spring事务支持的奇怪行为

我在相对简单的用例上发现了非常奇怪的行为,可能因为对spring@Transactional性质的了解不深,我无法理解它,但这很有趣。我有一个简单的用户dao,它扩展了springJpaDaoSupport类并包含标准保存方法:@TransactionalpublicUsersave(Useruser){getJpaTemplate().persist(user);returnuser;}如果在我向同一个类添加新方法之前工作正常:UsergetSuperUser(),此方法应该返回isAdmin==true的用户,如果数据库中没有super用户,方法应该创建一个。这就是它的样子:pub

java - 如何避免在服务类中重复 DAO 方法? @Transactional 注释 DAO 和服务类 - 这是可以接受的做法吗?

我知道最佳实践是同时拥有服务层和Dao层,并在服务层添加@Transactional注解。但在我的例子中,这意味着我的大部分服务类都是为了重复DAO方法而创建的……这很烦人。例如。publicinterfaceFooDAO{publicListlist(intcathegoryId);publicListlist(intcathegoryId,intownerId);}@Service@TransactionalpublicclassFooService{protected@AutowiredFooDAOdao;publicListlist(intcathegoryId){dao.li

java - @Transactional 在 CDI Bean 的基类中被忽略

具有以下相当简单的代码和正确配置的基于JTA的持久性上下文:abstractclassAbstractRepository{@PersistenceContextprotectedEntityManagerem;@Transactionalpublicsynchronizedvoidpersist(Eentity){em.persist(entity);em.flush();}}@ApplicationScopedclassMyEntityRepositoryextendsAbstractRepository{}我在调用MyEntityRepository.persist()时遇到以下

java - Guice @Transactional 不启动事务

我已经开始使用Guice方法级事务,如所述here.我有这样的消息@InjectprivateEntityManagerentityManager;@TransactionalpublicUserSessioncreateSession(Useruser,Stringbrowser){UserSessionsession=newUserSession(user,browser);entityManager.persist(session);}从简短的描述来看,我认为wis应该足够了。但是我得到一个错误,因为没有交易开始。仅当我自己开始并提交时它才有效。该对象是由Guice在我的应用程序

java - @Transactional (noRollbackFor=RuntimeException.class) 不会阻止在 RuntimeException 上回滚

@Transactional(noRollbackFor=RuntimeException.class)publicvoidmethodA(Entitye){service.methodB(e);}---以下服务方式---@Transactional(propagation=Propagation.REQUIRES_NEW,noRollbackFor=RuntimeException.class)publicvoidmethodB(Entitye){dao.insert(e);}当methodB()中的dao.insert(e)导致主键冲突并抛出ConstraintViolationE

java - 自定义 Spring AOP Around + @Transactional

我实现了自定义Around以匹配自定义注释。我希望自定义在外部@Transactional中执行。不幸的是,这似乎不起作用。(AOP正在运行。我看到显示它的堆栈跟踪)。堆栈跟踪显示我的AOP在(记录器)之前执行,MyBatissession开始一个事务,MyBatis关闭事务,Spring关闭事务然后我的AOP完成。我认为让我的AOP实现Ordered会有所帮助。我将返回的值设置为1。我使用.这没有用。我认为这是因为我误解了Spring的命令方式。AdviceorderingWhathappenswhenmultiplepiecesofadviceallwanttorunatthesa