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

标签 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();
    }
}

持久性.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 包中。

最佳答案

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

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

关于java - JPA query.getResultList() 返回错误的对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18292588/

相关文章:

java - 在EntityManager中执行JoinTransaction出现异常

java - 将 BigDecimal 转换为 String,以便在 JPQL 查询中使用 LIKE 过滤某些 BigDecimal id

java - Apache Felix 过滤器问题

java - 如何使用带有 TextView 列表的单选按钮

java - parent 的 onAreaTouched 会触发 child 的吗?

java - 此 sql 查询的 jpql 等效项(从国家字符查询)

java - 在 JSON 填充的 Android View 中单击的复选框列表

java - CriteriaQuery 加入字符串值

java - 使用 JPQL 从实体的 ElementCollections 中删除

java - 如何在 JPQL 中按 SUM() 排序