예제 #1
0
 @Override
 public Aluno buscarPorCodigo(Long codigo) {
   Aluno resultado = null;
   Session sessao = HibernateUtil.getSessionFactory().openSession();
   try {
     Criteria consulta = sessao.createCriteria(Aluno.class, "aluno");
     consulta.createAlias("aluno.usuario", "usuario");
     consulta.createAlias("aluno.curso", "curso");
     consulta.createAlias("usuario.fatec", "fatec");
     consulta.add(Restrictions.idEq(codigo));
     resultado = (Aluno) consulta.uniqueResult();
   } catch (RuntimeException runtimeException) {
     throw runtimeException;
   } finally {
     sessao.close();
   }
   return resultado;
 }
예제 #2
0
  public void excluir(Aluno aluno) {
    Session sessao = HibernateUtil.getSessionFactory().openSession();
    Transaction transacao = null;

    try {
      transacao = sessao.beginTransaction();
      sessao.delete(aluno);
      sessao.delete(aluno.getUsuario());
      transacao.commit();
    } catch (RuntimeException runtimeException) {
      if (transacao != null) {
        transacao.rollback();
      }
      throw runtimeException;
    } finally {
      sessao.close();
    }
  }
예제 #3
0
 @SuppressWarnings("unchecked")
 @Override
 public List<Aluno> listar() {
   List<Aluno> resultado = null;
   Session sessao = HibernateUtil.getSessionFactory().openSession();
   try {
     Criteria consulta = sessao.createCriteria(Aluno.class, "aluno");
     consulta.createAlias("aluno.usuario", "usuario");
     consulta.createAlias("usuario.fatec", "fatec");
     consulta.add(Restrictions.eq("usuario.tipoUsuario", TipoUsuario.ALUNO.getSigla()));
     consulta.addOrder(Order.asc("usuario.nome"));
     consulta.addOrder(Order.asc("fatec.nome"));
     resultado = consulta.list();
   } catch (RuntimeException runtimeException) {
     throw runtimeException;
   } finally {
     sessao.close();
   }
   return resultado;
 }