ฉันมีปัญหาในการทำธุรกรรมภายในวิธี @Transactional ของฉัน:
methodA() {
methodB()
}
@Transactional
methodB() {
...
em.persist();
...
em.flush();
log("OK");
}
เมื่อฉันเรียก methodB () จาก methodA () เมธอดจะผ่านไปได้สำเร็จและฉันสามารถเห็น "ตกลง" ในบันทึกของฉัน แต่แล้วฉันก็เข้าใจ
Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnly org.springframework.transaction.TransactionSystemException: Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnly
at org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.java:521)
at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:754)
at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:723)
at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:393)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:120)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:622)
at methodA()...
- บริบทของ methodB ขาดหายไปอย่างสมบูรณ์ในข้อยกเว้น - ฉันคิดว่าอะไรดี?
- มีบางอย่างภายใน methodB () ทำเครื่องหมายว่าธุรกรรมเป็นการย้อนกลับเท่านั้น? ฉันจะหามันได้อย่างไร? ตัวอย่างเช่นมีวิธีตรวจสอบบางอย่าง
getCurrentTransaction().isRollbackOnly()?
เช่นนี้หรือไม่ฉันสามารถทำตามขั้นตอนและค้นหาสาเหตุได้