【问题标题】:Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment] (trying to use EntityManager)无法创建请求的服务 [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment](尝试使用 EntityManager)
【发布时间】: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&amp;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


【解决方案1】:

原因:java.sql.SQLException:找不到合适的驱动程序 jdbc:mysql://localhost:3306/carent?useSSL=false&serverTimezone=UTC

这个异常是缺少jdbc驱动或者jdbc驱动url不匹配jdbc驱动引起的。 SO eerify javax.persistence.jdbc.url 并将驱动程序 jar 包含到类路径中。

更新: 默认依赖范围是compile。此范围意味着您需要 JAR 来编译和运行应用程序。

已提供 表示您需要 JAR 进行编译,但在运行时应用程序期望容器或 jdk 提供依赖项。因此,这些工件不需要将其打包在应用程序中。

请参阅maven dependency scope documentation 以检查传递依赖范围。可以通过依赖树来验证依赖范围。

mvn dependency:tree

[INFO] +- org.hibernate:hibernate-core:jar:5.2.12.Final:provided
[INFO] |  +- org.jboss.logging:jboss-logging:jar:3.3.0.Final:provided
[INFO] |  +- org.javassist:javassist:jar:3.20.0-GA:provided
[INFO] |  +- antlr:antlr:jar:2.7.7:provided
[INFO] |  +- org.jboss.spec.javax.transaction:jboss-transaction-api_1.2_spec:jar:1.0.1.Final:provided
[INFO] |  +- org.jboss:jandex:jar:2.0.3.Final:provided
[INFO] |  +- com.fasterxml:classmate:jar:1.3.0:provided
[INFO] |  +- dom4j:dom4j:jar:1.6.1:provided
[INFO] |  \- org.hibernate.common:hibernate-commons-annotations:jar:5.0.1.Final:provided

在您的情况下,dom4j 库存在问题。您需要确定它的来源,并确保和设置所需的范围和传递依赖项可以被排除。

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>5.2.12.Final</version>
    <exclusions>
        <exclusion>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
        </exclusion>
    </exclusions>
</dependency>

【讨论】:

  • 但我想我检查了一切,当我通过 IntelliJ 测试与 DB 的连接时一切正常。我有所有必需的依赖项,并且与 SessionFactory 的连接也正常......当我从这个依赖项中删除范围提供时,我从 dom4j 收到一个错误(正如我在消息末尾提到的那样)......有什么想法吗?
【解决方案2】:

问题解决了。 Wildfly 提供了一些依赖项,因此我必须使用 dependencyManagement 标记和 org.jboss.spec - jboss-javaee-7.0 依赖项,并按照提供的方式设置我的一些依赖项(即休眠)。 更重要的是 - 我开始使用依赖注入,而不是在我的 servlet 中使用 new 词创建新对象(来自 DAO)。

但感谢您的回答!

【讨论】:

    猜你喜欢
    • 2016-07-20
    • 2021-02-23
    • 2017-03-27
    • 1970-01-01
    • 1970-01-01
    • 2020-10-13
    • 1970-01-01
    • 2017-09-18
    • 2020-01-28
    相关资源
    最近更新 更多