【问题标题】:how to setup JPA project to work with Hibernate?如何设置 JPA 项目以使用 Hibernate?
【发布时间】:2014-07-18 17:47:00
【问题描述】:

我在 Eclipse 中设置一个使用纯 JPA 机制但使用 Hibernate 作为实现层的项目时遇到问题。

我有一个简单的程序,其中有 2 个类通过多对多关系链接,所有类都使用注释定义。

为了尽可能独立于数据库,我想避免使用休眠特定配置。例如,我希望我的所有配置都在 persistence.xml 文件中。

每次我启动程序时都会出现以下错误:

juil. 18, 2014 7:28:11 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
juil. 18, 2014 7:28:11 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
juil. 18, 2014 7:28:11 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
juil. 18, 2014 7:28:11 PM org.hibernate.jpa.internal.util.LogHelper logPersistenceUnitInformation
INFO: HHH000204: Processing PersistenceUnitInfo [
    name: Test-Cache-Hibernate
    ...]
juil. 18, 2014 7:28:11 PM org.hibernate.Version logVersion
INFO: HHH000412: Hibernate Core {4.3.5.Final}
juil. 18, 2014 7:28:11 PM org.hibernate.cfg.Environment <clinit>
INFO: HHH000206: hibernate.properties not found
juil. 18, 2014 7:28:11 PM org.hibernate.cfg.Environment buildBytecodeProvider
INFO: HHH000021: Bytecode provider name : javassist
juil. 18, 2014 7:28:11 PM org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>
INFO: HCANN000001: Hibernate Commons Annotations {4.0.4.Final}
Initial SessionFactory creation failed.javax.persistence.PersistenceException: Unable to build entity manager factory

上下文: 日食月神 JPA 2.1 休眠 4.3.5

这是我的 persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" 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">
    <persistence-unit name="Test-Cache-Hibernate" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
        <non-jta-data-source>datasource</non-jta-data-source>
        <shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
        <properties>
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/testcache"/>
            <property name="javax.persistence.jdbc.user" value="root"/>
            <property name="javax.persistence.jdbc.password" value="admin"/>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
        </properties>
    </persistence-unit>
</persistence>

我已将实体管理器的创建隔离在 Singleton 类中,如下所示:

package src.persistence.dbmanager;

import javax.persistence.EntityManager;
import javax.persistence.Persistence;

public class DBManager {

    public static final EntityManager entityManager;

    static {
        try {
            entityManager = Persistence.createEntityManagerFactory("Test-Cache-Hibernate").createEntityManager();
        } catch (Throwable ex) {
        throw new ExceptionInInitializerError(ex);
        }
    }

    public static EntityManager getEntityManager() {
        return entityManager;
    }
}

当我使用以下方法在 DAO 对象中手动注入 EntityManager 时,出现上述错误:

private EntityManager entityManager = DBManager.getEntityManager();

编辑 1: 这是我的 DAO 对象之一的代码:

package acs.testcache.persistence.dao;

import java.util.HashSet;
import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;

import acs.testcache.persistence.entities.MyChildObject;
import acs.testcache.persistence.entities.MyParentObject;


public class MyChildDAO extends MyCommonDAO<MyChildObject> {

    @PersistenceContext(unitName="Test-Cache-Hibernate")
    private EntityManager entityManager;

    public MyChildDAO() {
        super(MyChildObject.class);
    }

    public EntityManager getEntityManager() {
        return entityManager;
    }

    @SuppressWarnings("unchecked")
    public void getParents(MyChildObject c){

        StringBuilder hqlQuery = new StringBuilder();
        hqlQuery.append("select c.parentsObjects from MyChildObject c where c.id = :id");

        Query q = getEntityManager().createQuery(hqlQuery.toString()).setParameter("id", c.getId()).setHint("org.hibernate.cacheable", true);
        List<MyParentObject> result = q.getResultList();

        c.setParents(new HashSet<MyParentObject>(result));
    }
}

永远不会注入持久性管理器。

当我尝试使用注释自动注入它时,查询时出现空指针异常。

有人可以帮忙吗?

谢谢。

【问题讨论】:

  • 从那以后你解决了吗?

标签: java xml hibernate jpa


【解决方案1】:

请提供您如何使用注解注入EntityManager 的代码。你试过像这样使用@PersistenceContext注解吗?

@PersistenceContext private EntityManager entityManager;

在这种情况下,使用 @Component@Resource(或任何 Java 的原生等效注解)将不起作用。

【讨论】:

  • 感谢您的回答。请参阅我的编辑 1。我尝试使用 @PersistenceContext 无济于事,实体管理器从未注入。我终于能够通过从persistence.xml中删除&lt;non-jta-datasource&gt;标签来运行它,但我不明白为什么它突然起作用,因此对我来说不是一个好的解决方案。
【解决方案2】:

persistence.xml 我看不到任何实体声明。您应该在此处定义实体类。类似于&lt;class&gt;com.example.package.TestEntity&lt;class&gt;

同样在您的DBManager 中,您应该指定您的资源和EntityManger 是什么。使用 DI,例如: @PersistenceContext(unitName = "Test-Cache-Hibernate")
private EntityManager em;

【讨论】:

  • 这个问题与缺少实体无关。
  • @JamesB 真的。但这将是他的下一个问题。我解决了我在代码中看到的两个问题。丢失的实体就是其中之一。
  • @JamesB 感谢您的提示,但我的理解是自动检测到带有 @Entity 注释的实体。我错了吗 ?关于@PersistenceContext,请参阅我的编辑1,这不能正常工作。我拥有实体管理器的唯一方法是显式调用private EntityManager entityManager = DBManager.getEntityManager();
  • @Marco 实体检测是自动的,如果您在 persistence.xml 中定义了实体的类,否则您将最终出现未知实体异常 (java.lang.IllegalArgumentException: Unknown entity ...)
猜你喜欢
  • 2013-09-02
  • 2013-03-19
  • 1970-01-01
  • 1970-01-01
  • 2012-08-21
  • 1970-01-01
  • 1970-01-01
  • 2010-12-09
  • 2012-05-03
相关资源
最近更新 更多