WebService中未处理SQL异常



我们开发了无状态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的方法中捕获异常。

相关内容

  • 没有找到相关文章

最新更新