java – Spring托管事务,EclipseLink JPA,自定义隔离级别
发布时间:2020-12-14 05:53:38 所属栏目:Java 来源:网络整理
导读:我怀疑这是令人尴尬的,我以一种可怕的方式做错了,但请耐心等待我. 我有一个Spring应用程序与Spring管理的事务. 它使用EclipseLink JPA. 我有一个方法,它执行findByNativeQuery()后跟merge().我需要在真正的SERIAL事务隔离级别中实现这一点. 我尝试添加 @Tran
我怀疑这是令人尴尬的,我以一种可怕的方式做错了,但请耐心等待我.
我有一个Spring应用程序与Spring管理的事务. 这不起作用,因为org.springframework.orm.jpa.vendor.EclipseLinkJpaDialect #beaTransaction "java.lang.IllegalStateException : Not allowed to create transaction on shared EntityManager - use Spring transactions or EJB CMT instead 这当然有道理……但我该怎么办? 解决方法
我试过这个,但我不完全确定解决方案.我从
this blog获取了代码并将其改编为EclipseLink.这是代码:
package com.byteslounge.spring.tx.dialect; import java.sql.SQLException; import javax.persistence.EntityManager; import javax.persistence.PersistenceException; import org.eclipse.persistence.sessions.UnitOfWork; import org.springframework.orm.jpa.vendor.EclipseLinkJpaDialect; import org.springframework.transaction.TransactionDefinition; import org.springframework.transaction.TransactionException; public class CustomEclipseLinkJpaDialect extends EclipseLinkJpaDialect { private static final long serialVersionUID = 1L; private boolean lazyDatabaseTransaction = false; @Override public void setLazyDatabaseTransaction(boolean lazyDatabaseTransaction) { this.lazyDatabaseTransaction = lazyDatabaseTransaction; } @Override public Object beginTransaction(final EntityManager entityManager,final TransactionDefinition definition) throws PersistenceException,SQLException,TransactionException { UnitOfWork uow = (UnitOfWork) getSession(entityManager); uow.getLogin().setTransactionIsolation(definition.getIsolationLevel()); entityManager.getTransaction().begin(); if (!definition.isReadOnly() && !lazyDatabaseTransaction) { uow.beginEarlyTransaction(); } return null; } } 我发现事务启动时会记录SERIALIZABLE隔离,但需要对其进行正确测试以确认其有效. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |