Package br.gov.serpro.ouvidoria.dao.hibernate

Source Code of br.gov.serpro.ouvidoria.dao.hibernate.HibernateDao

/*
* Sistema de Ouvidoria: um canal através do qual os usuários
* podem encaminhar suas reclamações, elogios e sugestões.
*
* Copyright (C) 2011 SERPRO
*
* Este programa é software livre; você pode redistribuí-lo e/ou
* modificá-lo sob os termos da Licença Pública Geral GNU, conforme
* publicada pela Free Software Foundation; tanto a versão 2 da
* Licença como (a seu critério) qualquer versão mais nova.
*
* Este programa é distribuído na expectativa de ser útil, mas SEM
* QUALQUER GARANTIA; sem mesmo a garantia implícita de
* COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM
* PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais
* detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral GNU,
* sob o título "LICENCA.txt", junto com esse programa. Se não,
* acesse o Portal do Software Público Brasileiro no endereço
* http://www.softwarepublico.gov.br/ ou escreva para a Fundação do
* Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02111-1301, USA.
*
* Contatos através do seguinte endereço internet:
* http://www.serpro.gov.br/sistemaouvidoria/
*/
package br.gov.serpro.ouvidoria.dao.hibernate;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Criterion;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import br.gov.serpro.ouvidoria.dao.Dao;
import br.gov.serpro.ouvidoria.dao.DaoException;
import br.gov.serpro.ouvidoria.model.Identifiable;
import br.gov.serpro.ouvidoria.util.Constants;
import br.gov.serpro.ouvidoria.util.HibernateSessionFactory;

/**
*
* Objetivo: Implementar a interface Dao para o Hibernate.
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/19 20:36:56 $
* @version 0.1, Date: 2004/12/27
*/
public class HibernateDao implements Dao {

  private static final long serialVersionUID = 1L;

  private final Log log = LogFactory.getLog(HibernateDao.class);

  private Class clazz;

  /**
   * Construtor do HibernateDao.
   *
   * Pega uma sessão usando o HibernateSessionFactory.
   *
   * @see br.gov.serpro.ouvidoria.util.HibernateSessionFactory
   */
  public HibernateDao(Class clazz) {
    this.clazz = clazz;
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#save(br.gov.serpro.ouvidoria.model.Identifiable)
   */
  public void save(Identifiable object) throws DaoException {

    if (object == null) {
      throw new DaoException("Tentativa de persistir um Objeto nulo.");
    }

    Transaction trans = null;
    try {

      Session session = HibernateSessionFactory.getFactory().getSession();
      trans = session.beginTransaction();
      session.saveOrUpdate(object);
      session.flush();
      trans.commit();

    } catch (HibernateException e) {

      try {
        System.out.println(e.getMessage());
        trans.rollback();
      } catch (HibernateException e1) {
        log.error(e1);
      }

      log.error(e);
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      // fecha-se a sessão.
      HibernateSessionFactory.getFactory().closeSession();
      throw new DaoException("DAO SAVE ERROR: " + errorMessage, e);
    }
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#delete(br.gov.serpro.ouvidoria.model.Identifiable)
   */
  public void delete(Identifiable object) throws DaoException {

    if (object == null) {
      throw new DaoException("Tentado excluir um Objeto nulo.");
    }

    try {
      Session session = HibernateSessionFactory.getFactory().getSession();
      Transaction trans = session.beginTransaction();
      session.delete(object);
      trans.commit();
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO DELETE ERROR: " + errorMessage, e);
    }
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#delete(java.lang.Long)
   */
  public void delete(Long id) throws DaoException {

    if (id == null) {
      throw new DaoException("ID do Objeto não pode ser nulo.");
    }

    delete((Identifiable) get(id));
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#get(java.lang.Long)
   */
  public Object get(Long id) throws DaoException {
    if (id == null) {
      throw new DaoException("ID do Objeto não pode ser nulo.");
    }
    Session session = HibernateSessionFactory.getFactory().getSession();
    try {
      if (Constants.DEBUG) {
        System.out.println("\n***** OBTENDO " + this.clazz.getName()
            + " DE ID=" + id + " *****");
      }

      Object obj = session.get(this.clazz, id);
      return obj;
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO GET ERROR: " + errorMessage, e);
    }
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#find(java.lang.Object)
   */
  public List find(Object[] criteria) throws DaoException {

    if (criteria == null || criteria.length == 0) {
      throw new DaoException("Critério de busca não pode ser nulo.");
    }

    Session session = HibernateSessionFactory.getFactory().getSession();
    try {

      Criteria crit = session.createCriteria(this.clazz);

      for (int i = 0; i < criteria.length; i++) {
        crit.add((Criterion) criteria[i]);
      }
      List list = crit.list();
      return list;
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO FIND ERROR: " + errorMessage, e);
    }
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#list()
   */
  public List list() throws DaoException {

    Session session = HibernateSessionFactory.getFactory().getSession();

    try {

      Query query = session.createQuery("from " + this.clazz.getName());

      List list = query.list();
      return list;
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO LIST ERROR: " + errorMessage, e);
    }
  }

  /*
   * (non-Javadoc)
   *
   * @see br.gov.serpro.ouvidoria.dao.Dao#query(java.lang.String)
   */
  public List query(String textoHql) throws DaoException {
    return query(textoHql, -1, -1);
  }

  /**
   * Executa uma consulta, especificando a quantidade máxima de registros a
   * ser devolvida e a posição do registro a partir de onde o restante será
   * obtido.
   *
   * IMPORTANTE: a posição do registro inicial deve ser maior ou igual a zero
   * (posRegistroInicial >= 0) e a quantidade máxima de registros a ser
   * devolvida deve ser maior que zero (maxRegistros > 0); caso contrário,
   * esses argumentos não terão efeito sobre a query.
   *
   * @param textoHql
   *            texto da query em formato HQL (Hibernate).
   * @param posRegistroInicial
   *            posição do registro inicial.
   * @param maxRegistros
   *            quantidade máxima de registros a obter a partir do registro
   *            inicial.
   */
  public List query(String textoHql, int posRegistroInicial, int maxRegistros)
      throws DaoException {
    // obter a sessão do Hibernate
    Session session = HibernateSessionFactory.getFactory().getSession();

    try {
      if (Constants.DEBUG) {
        System.out
            .println("################## EXECUTANDO QUERY ################");
        System.out.println(textoHql);
      }

      // criar o objeto Query
      Query query = session.createQuery(textoHql);

      // indicar a posição do primeiro registro a ser devolvido
      if (posRegistroInicial >= 0) {
        query.setFirstResult(posRegistroInicial * maxRegistros);
      }

      // indicar a quantidade máxima de registros a ser buscada
      if (maxRegistros > 0) {
        query.setMaxResults(maxRegistros);
      }

      // executar a query
      List resultados = query.list();

      if (Constants.DEBUG) {
        System.out
            .println("################## TERMINOU A QUERY ################");
      }

      return resultados;
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO QUERY ERROR: " + errorMessage, e);
    }
  }

  public List query(Query query) throws DaoException {
    return query(query, -1, -1);
  }

  /**
   * Executa uma consulta, especificando a quantidade máxima de registros a
   * ser devolvida e a posição do registro a partir de onde o restante será
   * obtido.
   *
   * IMPORTANTE: a posição do registro inicial deve ser maior ou igual a zero
   * (posRegistroInicial >= 0) e a quantidade máxima de registros a ser
   * devolvida deve ser maior que zero (maxRegistros > 0); caso contrário,
   * esses argumentos não terão efeito sobre a query.
   *
   * @param query
   *            query do Hibernate.
   * @param posRegistroInicial
   *            posição do registro inicial.
   * @param maxRegistros
   *            quantidade máxima de registros a obter a partir do registro
   *            inicial.
   */
  public List query(Query query, int posRegistroInicial, int maxRegistros)
      throws DaoException {

    try {
      if (Constants.DEBUG) {
        System.out
            .println("################## EXECUTANDO QUERY ################");
        System.out.println(query.getQueryString());
      }

      // indicar a posição do primeiro registro a ser devolvido
      if (posRegistroInicial >= 0) {
        query.setFirstResult(posRegistroInicial * maxRegistros);
      }

      // indicar a quantidade máxima de registros a ser buscada
      if (maxRegistros > 0) {
        query.setMaxResults(maxRegistros);
      }

      // executar a query
      List resultados = query.list();

      if (Constants.DEBUG) {
        System.out
            .println("################## TERMINOU A QUERY ################");
      }

      return resultados;
    } catch (HibernateException e) {
      String errorMessage = e.getMessage();
      if (e.getCause() != null && e.getCause().getMessage() != null) {
        errorMessage = e.getCause().getMessage();
      }
      throw new DaoException("DAO QUERY ERROR: " + errorMessage, e);
    }
  }

}
TOP

Related Classes of br.gov.serpro.ouvidoria.dao.hibernate.HibernateDao

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.