1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Hibernate: Criteria Projections com um property Collection

Tenho uma situação com um relacionamento mxn entre Usuario e Grupo, e preciso apenas dos campos id,nome de ambos:

public class Usuario{
    private int id;
    private String nome;
    private List<Grupo> grupos;
}

public class Grupo{
    private int id;
    private String nome;
    private List<Usuario> usuarios;
}

`Criteria`

...
Session session = em.unwrap(Session.class);
        Criteria criteria = session.createCriteria(Usuario.class, "t");
        criteria.createAlias("grupos", "grupos");
        criteria.setProjection(Projections.projectionList()
                .add(Projections.alias(Projections.property("t.id"), "id"))
                .add(Projections.alias(Projections.property("t.nome"), "nome"))
                .add(Projections.alias(Projections.property("t.grupos"), "grupos"))

                );
        criteria.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
        Collection<T> list = criteria.setMaxResults(limit.intValue())
                .setFirstResult(start.intValue()).list();
        return list;

mas exibe a seguinte exceção: java.lang.ArrayIndexOutOfBoundsException: 2;

Qual a melhor forma de trazer uma lista usando Criteria?

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

0 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags hibernate collections ou faça a sua própria pergunta.