JPA query.getResultList()返回错误的对象?

时间:2013-08-17 19:33:12

标签: java jpa jpql

我正在进行下面的查询,以测试JPA是否从数据库中检索预期结果。

我无法理解为什么row instanceof Ativo返回false。 row.getClass()返回br.meuspila.entity.Ativo,打印对象为br.meuspila.entity.Ativo[ id=1 ]。类的导入是可以的,并且在同一个包中没有名为Ativo的其他类。

// OUTPUT:
INFO:   br.meuspila.entity.Ativo[ id=1 ]  // row
INFO:   false  // row instanceof Ativo?
INFO:   class br.meuspila.entity.Ativo  // row.getClass()

MyMB课程:

package br.meuspila.mb;

import br.meuspila.database.JpaUtil;
import br.meuspila.entity.Ativo;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;

@ManagedBean
@SessionScoped
public class MyMB {

    public String teste = "testando, 123";

    /**
     * Creates a new instance of ManagedBean
     */
    public MyMB() {
    }

    public String getTeste() {
        return teste;
    }

    public void setTeste(String teste) {
        this.teste = teste;
    }

    public void actionTeste() {
        EntityManager em = JpaUtil.getInstance().createEntityManager();

        try {
            EntityTransaction t = em.getTransaction();
            t.begin();

            Query query = em.createQuery("select x from Ativo x");
            List result = query.getResultList();

            for (Object row : result) {
                System.out.println(row);
                System.out.println(row instanceof Ativo);
                System.out.println(row.getClass());
            }

            t.commit();

        } finally {
            em.close();
        }        
    }

}

JpaUtil类:

package br.meuspila.database;

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

public final class JpaUtil {

    private JpaUtil() {
    }

    public static JpaUtil getInstance() {
        return JpaUtilHolder.INSTANCE;
    }

    private static class JpaUtilHolder {
        private static final JpaUtil INSTANCE = new JpaUtil();
        private static final EntityManagerFactory EMF = Persistence.createEntityManagerFactory("MeusPila3_WebPU");
    }

    public EntityManager createEntityManager() {
        return JpaUtilHolder.EMF.createEntityManager();
    }
}

的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="MeusPila3_WebPU" transaction-type="JTA">
    <jta-data-source>jdbc/meuspiladb</jta-data-source>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
    <properties>
    </properties>
  </persistence-unit>
</persistence>

我的项目配置(Web项目):

JPA 2.1 - EclipseLink-2.5.0.v20130507-rNA
GlassFish Server 4

NetBeans IDE 7.3.1 (Build 201306052037)
Java: 1.7.0_25; Java HotSpot(TM) 64-Bit Server VM 23.25-b01
Runtime: Java(TM) SE Runtime Environment 1.7.0_25-b17
System: Windows 7 version 6.1 running on amd64; Cp1252; pt_BR (nb)

Project view on NetBeans 7.3.1

注意:JpaUtil类位于br.meuspila.database包内。

3 个答案:

答案 0 :(得分:2)

随机装载机出现!在没有看到整个应用程序的情况下我无法帮助 - 但是在这里你快速修复:从你的Ativo删除WEB-INF/lib类定义(更好的整个bean包),然后放入你所有的bean在容器lib路径中的存档内(请参阅容器文档)。这样,由于委托,bean类将始终从同一个加载器加载。

再次确保WEB-INF中没有bean类定义(既不在JAR中也不在普通的.class文件中)。如果您使用支持以下内容的构建工具,请尝试将bean放在单独的项目(子项目/模块/子模块)中,使其他项目依赖于它,并将依赖项范围设置为提供(或等效的,即编译和测试需要的类,但不得包含在输出工件,战争,罐子或耳朵中)

答案 1 :(得分:0)

正如@Rafaelle所说,我认为问题是我的单身人士课程:JpaUtil。通过删除该类来修复代码。

也许如果我改变那个课程,问题就会解决。我正在观察它并注意到我做了一些(可能)错误:在单例中我试图在内部类中创建2个实例(JpaUtilHolder)...也许我应该从该内部类中删除EMF并将其作为非静态类JpaUtil类的属性。

替换为MyMB:

EntityManager em = JpaUtil.getInstance().createEntityManager();

通过

EntityManagerFactory emf = Persistence.createEntityManagerFactory(PERSISTENCE_UNIT);
EntityManager em = emf.createEntityManager();

答案 2 :(得分:0)

在我的情况下,实体的组合PK与表的PK不同。 修复映射,解决问题。