Hibernate 如何捕获数据库底层异常
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
请问我如何才能捕捉到数据库底层异常
java.sql.BatchUpdateException 我不知道哪能捕获到,我只是在eclipse的console中找到这个报错信息 展开
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
请问我如何才能捕捉到数据库底层异常
java.sql.BatchUpdateException 我不知道哪能捕获到,我只是在eclipse的console中找到这个报错信息 展开
3个回答
展开全部
Hibernate的异常原来就是将异常包装成HibernateException发给你
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2015-07-11 · 知道合伙人数码行家
可以叫我表哥
知道合伙人数码行家
向TA提问 私信TA
知道合伙人数码行家
采纳数:25897
获赞数:1464983
2010年毕业于北京化工大学北方学院计算机科学与技术专业毕业,学士学位,工程电子技术行业4年从业经验。
向TA提问 私信TA
关注
展开全部
Throwable ct=e,lt=e;
for(;;){ct=ct.getCause();if(ct==null)break;lt=ct;}
底层不要处理异常直接抛 ;
或者捕捉e throw e ;
或者用e.cause构造异常。
for(;;){ct=ct.getCause();if(ct==null)break;lt=ct;}
底层不要处理异常直接抛 ;
或者捕捉e throw e ;
或者用e.cause构造异常。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
底层的异常信息不是已经抛给你了吗?就是主键已存在的异常阿,不知道还想要什么样的详细信息,即使是自己写JDBC,最多也就是获取这样的异常而已。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询