人!
我编写代码JPA / HQL并运行,但它出现错误消息。说:
java.lang.IllegalArgumentException: An exception occurred while creating a query in EntityManager: Exception Description: Syntax error parsing the query [Select t.disciplina.nomeDisciplina, n.notaFinal From (Select f.notas as notas, sum(f.f1 + f.f2 + f.f3 +f.f4) as soma from Frequencia f group by f.notas) subquery inner join subquery.notas n inner join n.aluno1 a inner join n.turma1 t inner join a.usuario u where u = ?1], line 1, column 54: unexpected token [(].Internal Exception: org.eclipse.persistence.internal.jpa.parsing.jpql.InvalidIdentifierException
我使用子句子查询创建HQL(查询),见下文。
public List<Object[]> getListNotasFrequencia(Usuario u) {
EntityManager em = getEntityManager();
List<Object[]> lista = new Vector<Object[]>();
String query = "Select t.disciplina.nomeDisciplina, n.notaFinal "
+ " From (Select f.notas as notas, sum(f.f1 + f.f2 + f.f3 +f.f4) as soma from Frequencia f group by f.notas) subquery "
+ " inner join subquery.notas n"
+ " inner join n.aluno1 a"
+ " inner join n.turma1 t"
+ " inner join a.usuario u"
+ " where u = ?1";
try {
lista = em.createQuery(query).setParameter(1, u).getResultList();
} finally {
em.close();
}
return lista;
}
我已多次对此代码进行错误修改,但错误信息相同。
请!您可以帮助或暗示此代码。我开始学习这个JPA / JPQL。
谢谢!!!
答案 0 :(得分:0)
问题是FROM子句中的子选择,JPA不支持此选项。 EclipseLink确实对此有一定程度的支持,但是你继续为这个不存在的对象建立别名关系,所以我看不出你希望它如何工作。
将查询重新编写为仅使用普通连接,或使用本机SQL查询。