我们开发了无状态Web服务实现。我们使用JPA作为ORM层来进行数据库操作。在服务方法中,我们使用实体管理器来持久化实体。在将相同的记录持久化到表中时,我们无法处理那些异常"Caused by: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: unique constraint (TIGOSUSCRIPTIONES.SYS_C0020549) violated" exception in Service method. It is directly throwing the following exception in client result.
Exception in thread "main" javax.xml.ws.soap.SOAPFaultException: Transaction rolled back
at com.sun.xml.internal.ws.fault.SOAP11Fault.getProtocolException(SOAP11Fault.java:178)
at com.sun.xml.internal.ws.fault.SOAPFaultBuilder.createException(SOAPFaultBuilder.java:111)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:108)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:78)
at com.sun.xml.internal.ws.client.sei.SEIStub.invoke(SEIStub.java:107)
at $Proxy30.registerSaleOutcome(Unknown Source)
如何处理此异常。以下是我们在服务方法业务逻辑中使用的代码。
@TransactionAttribute(TransactionAttributeType.REQUIRED)
public void recycleOperation(Recycle recycle) throws RecycleFault_Exception{
try{
em.persist(recycle);
} catch(Exception e){
//not coming to this block
log.error("Exception in Data Insertion:"+e.getMessage());
RecycleFault fault = new RecycleFault();
fault.setErrorCode("101");
fault.setMessage("Record is already Existed");
RecycleFault_Exception faultExp = new RecycleFault_Exception("RecycleFault Exception", fault);
throw faultExp;
}
}
你能帮我解决这个问题吗。
提前感谢。
当您调用em.persist(recycle);
时,您的recycle
对象将附加EntityManager。这并不意味着recycle
对象会立即插入(持久化(到数据库中。在提交正在进行的事务时,EntityManager将recycle
对象插入数据库。看起来您的public void recycleOperation
方法是Transactional。这意味着EntityManager在完成recycleOperation
方法的执行之后插入recycle
对象。因此,当recycleOperation
方法的执行完成时,您看到的异常就会出现。
长话短说,您应该在调用recycleOperation
的方法中捕获异常。