Lorsque j'essaie d'exécuter cette HQL pour retourner un objet Ponto
, je reçois cette erreur:
ERREUR [org.hibernate.hql.PARSER] (http-localhost-127.0.0.1-8080-2) Impossible de localiser le constructeur approprié sur la classe [Br.com.cdv.model.entity .Ponto] [Cause = org.hibernate.PropertyNotFoundException: pas de constructeur Approprié dans la classe: br.com.cdv.model.entity.Ponto]
DAO
@SuppressWarnings("unchecked")
@Override
public List<Ponto> listLoja(Integer idLoja) {
Query q = getSession().createQuery("select new Ponto(0,ss.cliente,ss.loja,null,null,null,null,null,sum(qtdPontos),'',0) "
+ "from Ponto as ss where ss.loja.id = :idLoja "
+ "group by ss.cliente, ss.loja");
q.setParameter("idLoja", idLoja);
return (List<Ponto>) q.list();
}
Mon entité/classe
@Entity
@Table (name = "ponto")
public class Ponto implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue
private Integer id;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="cliente", nullable=true)
private UsuarioCliente cliente;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="loja", nullable=false)
private UsuarioLoja loja;
@Column(name="dataCriacao")
private Date dataCriacao;
@Column(name="dataUtilizado", length=12, nullable=true)
private Date dataUtilizado;
@Column(name="dataExpira")
private Date dataExpira;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "funcionario", nullable=true)
private Funcionario funcionario;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "pontoReceber", nullable=true)
private PontoReceber pontoReceber;
@Column(name="qtdPontos", nullable=false)
private long qtdPontos;
@Column(name="obsPontos", nullable = true,length=300)
private String obsPontos;
@NotEmpty
@Column(name="tipo",nullable = false)
private Integer tipo;
public Ponto(Integer id, UsuarioCliente cliente,UsuarioLoja loja, Date dataCriacao, Date dataUtilizado,
Date dataExpira, Funcionario funcionario, PontoReceber pontoReceber, long qtdPontos, String obsPontos, Integer tipo) {
setId(id);
setCliente(cliente);
setLoja(loja);
setDataCriacao(dataCriacao);
setDataUtilizado(dataUtilizado);
setDataExpira(dataExpira);
setFuncionario(funcionario);
setPontoReceber(pontoReceber);
setQtdPontos(qtdPontos);
setObsPontos(obsPontos);
setTipo(tipo);
}
// getters and setters
}
Contrôle:
@RequestMapping("/listarClientes")
public String listarClientesPontos(Map<String, Object> map, HttpSession session) {
...
List<Ponto> pontos = pontoService.listLoja(loja.getId());
map.put("pontos", pontos);
return "listaClientesPonto";
}
}
Vue:
<%@taglib uri="http://Java.Sun.com/jsp/jstl/core" prefix="c"%>
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<body>
<h2>Lista Clientes</h2>
<table>
<tr>
<th>ID Cliente</th>
<th>CPF Cliente</th>
<th>Pontos totais:</th>
</tr>
<c:forEach items="${pontos}" var="ponto" varStatus="count">
<tr>
<td>${ponto.cliente.id}</td>
<td>${ponto.cliente.cpf}</td>
<td>${ponto.qtdPontos}</td>
</tr>
</c:forEach>
</table>
</body>
Pourquoi je reçois cette erreur?
Pourquoi ne pas recevoir cet objet Ponto dans une liste?
obs .. without new Ponto(...)
renvoie une liste de Ponto avec des objets non identifiés []
Trouvé le problème ... J'ai fait de mauvais constructeurs, alors j'ai édité les constructeurs de mon entité:
@Entity
@Table (name = "ponto")
public class Ponto implements Java.io.Serializable {
@Id
@GeneratedValue
private Integer id;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="cliente", nullable=true)
private UsuarioCliente cliente;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="loja", nullable=false)
private UsuarioLoja loja;
@Column(name="dataCriacao")
private Date dataCriacao;
@Column(name="dataUtilizado", length=12, nullable=true)
private Date dataUtilizado;
@Column(name="dataExpira")
private Date dataExpira;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "funcionario", nullable=true)
private Funcionario funcionario;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "pontoReceber", nullable=true)
private PontoReceber pontoReceber;
@Column(name="qtdPontos", nullable=false)
private long qtdPontos;
@Column(name="obsPontos", nullable = true,length=300)
private String obsPontos;
@NotEmpty
@Column(name="tipo",nullable = true)
private Integer tipo;
public Ponto() {
}
public Ponto(UsuarioCliente cliente, UsuarioLoja loja, long qtdPontos) {
this.cliente = cliente;
this.loja = loja;
this.qtdPontos = qtdPontos;
}
// getters and setters
}
et HQL:
Query q = getSession().createQuery("select new Ponto(ss.cliente,ss.loja,sum(ss.qtdPontos) as qtdPontos) "
+ "from Ponto as ss where ss.loja.id = :idLoja "
+ "group by ss.cliente, ss.loja");
q.setParameter("idLoja", idLoja);
Je pleure comme un bébé, quatre jours avec ce problème.
Merci pour les directions Thufir Hawat.
Vérifiez ces choses:
1- Si vous faites un constructeur avec des paramètres; vous devez fournir au constructeur aucun paramètre, explicite;
2- Assurez-vous que votre entité ID est int/Integer;
3- Rendre votre entité Java.io.Serializable en implémentant;
4- Rendez votre constructeur sans paramètre (par défaut) constructeur ou votre modificateur d'accès par défaut;
Faire un constructeur public avec des arguments peut le faire fonctionner.
Si vous avez fait une sélection (c’est-à-dire ne renvoyez pas toutes les colonnes de la table), assurez-vous d’avoir un constructeur avec la colonne sélectionnée dans votre classe mappée.