首页 > 解决方案 > 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; 
   } 
} 

你能帮我解决这个问题吗?

提前致谢。

标签: javasqlweb-servicesexception-handling

解决方案


当您调用时em.persist(recycle);,您的recycle对象将附加到您的 EntityManager。这并不意味着recycle对象立即插入(持久)到数据库中。recycle当正在进行的事务提交时,EntityManager 将对象插入数据库。看起来您的public void recycleOperation方法是事务性的。这意味着 EntityManagerrecycle在完成方法执行后插入对象recycleOperation。因此,您看到的异常是在recycleOperation方法执行完成时产生的。

长话短说,您应该在recycleOperation调用的方法中捕获异常。


推荐阅读