【发布时间】:2018-05-25 21:57:26
【问题描述】:
嗨,我正在使用 javaee、JPA/Hibernate、MySQL、Maven 和 IntelliJ 创建我的第一个严肃的网络应用程序。当我使用 SessionFactory 时一切正常,但我决定改用 Entitymanager - 我花了一整天时间修复错误,但我无法修复这个:
当我尝试通过我的 webapp 向数据库添加新行时出现错误:
javax.persistence.PersistenceException: Unable to build entity manager factory
org.hibernate.jpa.HibernatePersistenceProvider.createEntityManagerFactory(HibernatePersistenceProvider.java:66)
javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:55)
javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:39)
domain.CarDAO.<init>(CarDAO.java:8)
controller.CarToDbServlet.doPost(CarToDbServlet.java:17)
另外来自 IntelliJ 控制台:
Caused by: org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]
Caused by: org.hibernate.exception.JDBCConnectionException: Error calling DriverManager#getConnection
Caused by: java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/carent?useSSL=false&serverTimezone=UTC
这是我的 CarDAO 课程:
public class CarDAO {
private EntityManagerFactory emf = Persistence.createEntityManagerFactory("JPAPersistUnit");
private List<Car> carList = new ArrayList<>();
public void addCar(Car car) {
EntityManager em = emf.createEntityManager();
EntityTransaction trans = em.getTransaction();
try {
trans.begin();
em.persist(car);
trans.commit();
} catch (Exception ex) {
if(trans != null) {trans.rollback();}
ex.printStackTrace();
} finally {
em.close();
}
}
这是一个 persistence.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence
http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd" version="2.1">
<persistence-unit name="JPAPersistUnit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<class>domain.Car</class>
<class>domain.Customer</class>
<class>domain.Orders</class>
<properties>
<property name="javax.persistence.jdbc.Driver" value="com.mysql.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/carent?useSSL=false&serverTimezone=UTC"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password" value="root"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
<property name="hibernate.hbm2ddl.auto" value="create"/>
<property name="hibernate.format_sql" value="true"/>
</properties>
</persistence-unit>
</persistence>
这些是我在 pom.xml 中的依赖项:
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>5.2.12.Final</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.6</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0</version>
</dependency>
<dependency>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.1-api</artifactId>
<version>1.0.0.Final</version>
<scope>provided</scope>
</dependency>
</dependencies>
我在这里寻找解决方案,我发现了一些类似的主题,但根据他们的说法,我的代码似乎一切正常。也许这是 IntelliJ 的问题?但是我添加了一个数据源,它可以毫无问题地与我的数据库连接...... 当我删除 hibernate-core 和 hibernate-jpa 中提供的范围时,我收到此错误:
org.dom4j.DocumentFactory 不能转换为 org.dom4j.DocumentFactory
是不是和wildfly有关?
请帮忙:(
【问题讨论】:
-
您的部署中似乎包含了一个具有
org.dom4j.DocumentFactory的库。我还建议使用EntityManager管理的容器,而不是手动创建一个。
标签: mysql maven jpa intellij-idea wildfly