我开发了一个使用Hibernate访问PostgreSQL数据库的小型应用程序。当我尝试删除另一个表与外键有关的记录时,出现js javax.persistence.PersistenceException 以
下消息:
无法执行语句
但是我注意到在控制台窗口中,有一条更详细的消息,如下所示:
13:13:49,222 ERROR [org.hibernate.engine.jdbc.spi.SqlExceptionHelper] (default task-3) ERROR: update or delete on table "AdminSite" violates foreign key constraint "FK_AdminUserSite" on table "AdminUserProfile"
Detail: Key (STCode)=(HO ) is still referenced from the table "AdminUserProfile".
如何检索此消息更有意义?
Hibernate在JDBCException中包装与数据库交互时抛出的SQLException。实际上,Hibernate会尝试将异常转换为JDBCException的更完善的子类。底层的SQLException始终可以通过JDBCException.getCause()获得。
Hibernate文档指定了以上内容,可在hibernate文档中找到。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。