栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

调用getNextException以查看原因:如何使Hibernate / JPA显示数据库服务器消息中的异常

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

调用getNextException以查看原因:如何使Hibernate / JPA显示数据库服务器消息中的异常

无需编写任何自定义代码即可实现此目的-
默认情况下,Hibernate将记录异常原因。如果看不到此内容,则必须正确设置Hibernate日志记录。这是slf4j +
log4j的示例,并使用Maven进行依赖项管理。

src / main / java / pgextest / PGExceptionTest.java

public class PGExceptionTest {    public static void main(String[] args) throws Exception {        EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory(     "pgextest");        EntityManager entityManager = entityManagerFactory.createEntityManager();        entityManager.getTransaction().begin();        // here I attempt to persist an object with an ID that is already in use        entityManager.persist(new PGExceptionTestBean(1));        entityManager.getTransaction().commit();        entityManager.close();    }}

src / main / resources / log4j.properties

log4j.rootLogger=ERROR, stdoutlog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

src / main / resources / meta-INF / persistence.xml

<persistence xmlns="http://java.sun.com/xml/ns/persistence"        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"        xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"        version="2.0">    <persistence-unit name="pgextest">        <properties> <property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver"/> <property name="javax.persistence.jdbc.url" value="jdbc:postgresql://localhost/pgextest"/> <property name="javax.persistence.jdbc.user" value="postgres"/> <property name="javax.persistence.jdbc.password" value="postgres"/> <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/> <property name="hibernate.jdbc.batch_size" value="5"/>        </properties>    </persistence-unit></persistence>

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>    <groupId>pgextest</groupId>    <artifactId>pgextest</artifactId>    <version>0.0.1-SNAPSHOT</version>    <build>        <plugins> <plugin>     <artifactId>maven-compiler-plugin</artifactId>     <configuration>         <source>1.6</source>         <target>1.6</target>     </configuration> </plugin>        </plugins>    </build>    <dependencies>        <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>3.6.9.Final</version>        </dependency>        <dependency> <groupId>postgresql</groupId> <artifactId>postgresql</artifactId> <version>9.1-901.jdbc4</version> <scope>runtime</scope>        </dependency>        <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.6.1</version> <scope>runtime</scope>        </dependency>        <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.15</version> <scope>runtime</scope>        </dependency>    </dependencies></project>

然后执行main方法将记录以下内容:

ERROR [main] - Batch entry 0 insert into PGExceptionTestBean (label, id) values (NULL, '1') was aborted.  Call getNextException to see the cause.ERROR [main] - ERROR: duplicate key value violates unique constraint "pgexceptiontestbean_pkey"

这也许值得一提的是,您可以禁用JDBC批处理,通过属性设置包装原始异常

hibernate.jdbc.batch_size
0
(不用说了你可能不希望这样做生产。)



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/397744.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号