java 如何捕获数据库底层异常
org.hibernate.exception.ConstraintViolationException:CouldnotexecuteJDBCbatchupdateat...
org.hibernate.exception.ConstraintViolationException: Could not execute JDBC batch update
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:71)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:81)
……
……
省略
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.sql.BatchUpdateException: ORA-00001: unique constraint (SI.UK_CN_EN) violated
----说明---------------------------------------------------------------------------------------
我们的项目是SSH2
我现在只能捕获到HibernateException:Could not execute JDBC batch update
但是我想要捕获底层异常信息:java.sql.BatchUpdateException: ORA-00001: unique constraint (SI.UK_CN_EN) violated
请问我如何才能捕捉到数据库底层异常 展开
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:71)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:81)
……
……
省略
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.sql.BatchUpdateException: ORA-00001: unique constraint (SI.UK_CN_EN) violated
----说明---------------------------------------------------------------------------------------
我们的项目是SSH2
我现在只能捕获到HibernateException:Could not execute JDBC batch update
但是我想要捕获底层异常信息:java.sql.BatchUpdateException: ORA-00001: unique constraint (SI.UK_CN_EN) violated
请问我如何才能捕捉到数据库底层异常 展开
4个回答
展开全部
Throwable getCause()
返回此 throwable 的 cause;如果 cause 不存在或未知,则返回 null。
String getLocalizedMessage()
创建此 throwable 的本地化描述。
String getMessage()
返回此 throwable 的详细消息字符串。
返回此 throwable 的 cause;如果 cause 不存在或未知,则返回 null。
String getLocalizedMessage()
创建此 throwable 的本地化描述。
String getMessage()
返回此 throwable 的详细消息字符串。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
hibernate不就是把底层异常直接转发给你的吗。。
你用jdbc也就是这个异常信息
你要获取更底层的异常。。可能就只有写驱动了。。
你用jdbc也就是这个异常信息
你要获取更底层的异常。。可能就只有写驱动了。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
要想捕获底层异常,就需要你在调用底层的时候主动throw exception,或者说是人为的强行catch, then throw
和用Double.parseDouble()调用一样,主动去catch..
和用Double.parseDouble()调用一样,主动去catch..
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
Throwable ct=e,lt=e; for(;;){ct=ct.getCause();if(ct==null)break;lt=ct;} 底层不要处理异常直接抛 ; 或者捕捉e throw e ; 或者用e.cause构造异常。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询