- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于我的数据库的复杂性,我决定创建一个新对象,在其中仅指定我将使用的参数。为了进行自定义查询,我在 JPA 中使用 createNativeQuery。跟随我的对象。
POJO:
@Entity
public class Unidade implements Serializable{
private static final long serialVersionUID = 1L;
private Long numeroUnidade;
private String nomeUnidade;
private Integer numeroCep;
private Integer numeroCepComplemento;
private String tipoServico;
private Integer status;
private String logradouro;
private String bairro;
private String cidade;
private String uf;
private Integer statusVinculo;
//getter and setters
目前我正在使用以下选择来返回简单整数并且可以正常工作而不会出现任何问题。
@PersistenceContext(unitName="projetoAtividade")
private EntityManager em;
public void selectTeste(){
int quantidade = (Integer) em.createNativeQuery("select count(*) from abc.nattbu29_escritorio;").getSingleResult();
System.out.println("========== QUANTIDADE DE REGISTRO NA TABELA ===========");
System.out.println(quantidade);
}
虽然前面的查询工作正常,但是当提交一个复杂的查询并放置相应的别名时,使用createNativeQuery并放置对象返回,hibernate会抛出异常(org.hibernate.MappingException:未知)。
记住我创建了一个新类并指定 @Entity。
查询:
@SuppressWarnings("unchecked")
public List<UnidadeTeste> buscarUnidadeGenerica(int numeroCeps, int numeroComplementoCeps){
List<UnidadeTeste> lsita = new ArrayList<UnidadeTeste>();
String query = "SELECT "
+"TBZ21.NATURAL as numeroPv, "
+"TBZ21.UNIDADE as nomePv, "
+"TBZ21.SITUACAO as statusVinculacao, "
+"TBJ55.TPO_ATUACAO_U44 as tipoServAZW, "
+"TBJ55.SITUACAO_ATUAL as status, "
+"TBH18.LOCALIDADE as cidade, "
+"'' as bairro, "
+"'' as logradouro, "
+"TBH18.CEP as numeroCep, "
+"TBH18.CEP_COMPLEMENTO as numeroCepComplemento, "
+"TBH18.FK_AZWVWL22_UNISG as uf "
+"FROM AZW.AZWTBJ55_RGATUACAO TBJ55 "
+"LEFT JOIN AZW.AZWTBH18_LOCALIDADE TBH18 ON "
+"TBH18.LOCALIDADEE = TBJ55.LOCALIDADEE "
+"LEFT JOIN AZW.AZWTBZ21_UNIDADE TBZ21 ON "
+"TBJ55.NATURAL = TBZ21.NATURAL "
+"WHERE TBH18.CEP = ?1 "
+"AND TBH18.CEP_COMPLEMENTO = ?2; "
lsita = em.createNativeQuery(query, Unidade.class)
.setParameter(1, numeroCeps)
.setParameter(2, numeroComplementoCeps)
.getResultList();
System.out.println(lsita.size()+"<<<<=====================");
return lsita;
}
错误:
Caused by: org.hibernate.MappingException: Unknown entity: br.com.project.modelo.UnidadeTeste
at org.hibernate.internal.SessionFactoryImpl.getEntityPersister(SessionFactoryImpl.java:1031) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.loader.custom.sql.SQLQueryReturnProcessor.getSQLLoadable(SQLQueryReturnProcessor.java:336) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.loader.custom.sql.SQLQueryReturnProcessor.processRootReturn(SQLQueryReturnProcessor.java:377) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.loader.custom.sql.SQLQueryReturnProcessor.processReturn(SQLQueryReturnProcessor.java:356) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.loader.custom.sql.SQLQueryReturnProcessor.process(SQLQueryReturnProcessor.java:172) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.loader.custom.sql.SQLCustomQuery.<init>(SQLCustomQuery.java:87) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.query.spi.NativeSQLQueryPlan.<init>(NativeSQLQueryPlan.java:67) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.query.spi.QueryPlanCache.getNativeSQLQueryPlan(QueryPlanCache.java:155) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.internal.AbstractSessionImpl.getNativeSQLQueryPlan(AbstractSessionImpl.java:218) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.internal.AbstractSessionImpl.list(AbstractSessionImpl.java:224) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.internal.SQLQueryImpl.list(SQLQueryImpl.java:156) [hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:252) [hibernate-entitymanager-4.0.1.Final.jar:4.0.1.Final]
... 84 more
在我通过互联网搜索时,几乎所有论坛主题的解决方案答案都是一致的:“将 @Entity 放在类声明之前”,但是,这对我不起作用。
我“花了”一整天的时间试图寻找有效的解决方案,但不幸的是,我没有取得成功。有人可以说一个新的方法来解决我的问题吗?我在两个不同的项目中进行了测试,并发生了同样的问题。
问题补充:
各位,我尝试在我的类中创建一个 @SqlResultSetMapping,编码如下,但现在, hibernate 会引发另一个异常:
ERROR [org.jboss.ejb3.invocation] (http--127.0.0.1-8888-2) JBAS014134: EJB Invocation failed on component AtividadeEJB for method public void br.com.project.jboss.modelo.AtividadeEJB.testeChamada(): javax.ejb.EJBException: javax.persistence.PersistenceException: org.hibernate.MappingException: Unknown SqlResultSetMapping [UnidadeResult]
at org.jboss.as.ejb3.tx.CMTTxInterceptor.handleExceptionInOurTx(CMTTxInterceptor.java:166) [jboss-as-ejb3-7.1.1.Final.jar:7.1.1.Final]
at org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:230) [jboss-as-ejb3-7.1.1.Final.jar:7.1.1.Final]
at org.jboss.as.ejb3.tx.CMTTxInterceptor.required(CMTTxInterceptor.java:304) [jboss-as-ejb3-7.1.1.Final.jar:7.1.1.Final]
at org.jboss.as.ejb3.tx.CMTTxInterceptor.processInvocation(CMTTxInterceptor.java:190) [jboss-as-ejb3-7.1.1.Final.jar:7.1.1.Final]
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) [jboss-invocation-1.1.1.Final.jar:1.1.1.Final]
我的新 POJO:
@Entity
@SqlResultSetMapping(name="UnidadeResult",
entities={
@EntityResult(entityClass=UnidadeTeste.class, fields={
@FieldResult(name="tx_descricao", column="nomePv"),
@FieldResult(name="nu_idntr_pessoa", column="id")})},
columns={
@ColumnResult(name="nomePv")}
)
public class UnidadeTeste implements Serializable{
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue
private Long id;
private String nomePv;
public String getNomePv() {
return nomePv;
}
public void setNomePv(String nomePv) {
this.nomePv = nomePv;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
我的EJB:
@SuppressWarnings("unchecked")
public void testeChamada(){
List<Object> lista = em.createNativeQuery("SELECT nu_idntr_pessoa as id, email as nomePv FROM pessoa;", "UnidadeResult").getResultList();
System.out.println("===============>>"+lista.size());
}
最佳答案
如果您想将 native 查询的结果返回到对象,我建议使用 SqlResultSetMapping .
否则,将返回类型设置为:
List<Object[]> results = em.createNativeQuery(query)
.setParameter(1, numeroCeps)
.setParameter(2, numeroComplementoCeps)
.getResultList();
然后循环遍历结果列表,并将 Object 数组的每个成员转换为其数据类型。
关于java - 由 : org. hibernate.MappingException : Unknown entity: New Object. JTA 引起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36096092/
什么是 hibernate 和n- hibernate ?我可以在 Visual Studio 2008 中使用它进行 C# Web 应用程序开发吗?请给我建议...我是 asp.net Web 应用
我有一个不系统地发生的异常(exception)。 我试图通过在每次迭代中刷新和清理 session 来解决此问题,但没有成功。 [quartzScheduler_Worker-7] ERROR jd
使用 Hibernate 在数据库中存储 IP 地址的最佳类型是什么? 我虽然是 Byte[] 或 String,但有没有更好的方法,或者你用什么? @Column(name = "range_fr
我正在尝试制定一个公式来选择用户个人资料的用户友好名称。它选择名字 + ' ' + 姓氏 如果其中至少有一个不为空且不为空(包含非空白字符),否则选择 短名称 (条件相同),最后,如果 短名称 为空或
在hibernate中,是否可以将鉴别器作为一个实体?例如,如果我将 Department 作为基类,将 AdminDepartment 和 ProcessingDepartment 作为子类。 De
我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。 我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin
你好: 我对 hibernate 缓存缓存的内容感到困惑。 从文档中,我知道 hibernate 中有缓存类型。 一级 :交易级别。 似乎要被 session 持久化的实体被缓存在这里。 二级缓存 :
我遇到了一个情况: save或update hibernate 的目标表中的某些数据 在目标表上有一个触发器,该触发器将在目标表的insert或update操作之前执行 由 hibernate 将此记
我有一个名为 Master_Info_tbl 的表。它是一个查询表: 这是该表的代码: @Entity @Table(name="MASTER_INFO_T") public class Code
我想知道如何在 Hibernate 查询语言中使用日期文字。我在我的 JPA 项目中做了如下操作(作为 Eclipselink 提供者)并且它工作正常。 SELECT m FROM Me m WHER
@Entity public class Troop { @OneToMany(mappedBy="troop") public Set getSoldiers() { ...
我正在尝试使用 hibernate 查询删除表 'user_role' 中的所有行。但每次我都会出错。有人可以帮我吗。 DaoImpl @Override public void deleteAll(
不是将数据库操作分散在四个 (osgi) 包中,而是在那里做略有不同的事情。我想创建一个负责所有持久性问题的(简单的)OSGi 包。我觉得这并不像听起来那么简单,因为“每个包都有独特的类加载器”。 因
这就是我使用生成器的方式: private Integer id; 我看到的行为是: 创建第一个对象 hibernate 分配 id = 1 删除该对象 关闭服务
对象级别的实体和值类型有什么区别。我知道实体将有一个 id 但值不会,但为什么我们需要不同的方法来映射实体与值类型? 这样做是为了让hibernate可以对值类型应用任何优化吗? 最佳答案 一个实体已
我正在使用 HibernateTemplate.findByCriteria 方法进行一些查询。现在我想在标准上创建一些 SQL 限制,比如 criteria.add(Restrictions.sql
所以我有以下代码: Query query = session.createQuery("from Weather"); List list = query.list();
如何使用Hibernate映射具有多个实体的 View ? 问候, 混沌 最佳答案 请参见Hibernate文档中第5.1.3节“类”,紧接在“Id”节之前: There is no differen
据我所知,Hibernate 有两种类型的实现 JPA的实现(2)(@Entity,@Table注解) 扩展到旧的(传统的) hibernate (没有 JPA),使用 HSQL 查询,没有注释 如果
我需要一个将条目存储为键值对的集合(因此我可以通过键查找值),但我需要一个允许多个值使用 hibernate 共享同一个键的集合 最佳答案 一个键具有多个值的映射称为多映射 - 在 Apache 公共
我是一名优秀的程序员,十分优秀!