com.app.inventario.dao.ProveedorDAOImpl.java Source code

Java tutorial

Introduction

Here is the source code for com.app.inventario.dao.ProveedorDAOImpl.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.app.inventario.dao;

import com.app.inventario.daointerface.IDAO;
import com.app.inventario.entidades.Proveedor;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

/**
 *
 * @author Erick
 */
public class ProveedorDAOImpl extends HibernateDaoSupport implements IDAO<Proveedor> {

    private Session session;
    private Transaction tx;

    @Override
    public void guardar(Proveedor proveedor) throws HibernateException {
        try {
            this.iniciaOperacion();
            session.save(proveedor);
            tx.commit();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
    }

    @Override
    public void actualizar(Proveedor proveedor) {
        try {
            this.iniciaOperacion();
            session.update(proveedor);
            tx.commit();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
    }

    @Override
    public void eliminar(Proveedor proveedor) {
        try {
            this.iniciaOperacion();
            session.save(proveedor);
            tx.commit();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
    }

    @Override
    public Proveedor obtener(int id) {
        Proveedor result = null;
        try {
            this.iniciaOperacion();
            result = (Proveedor) session.get(Proveedor.class, id);
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            //tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
        return result;
    }

    @Override
    public List<Proveedor> obtenerTodos() {
        List<Proveedor> result = null;
        try {
            this.iniciaOperacion();
            result = session.createQuery("FROM Proveedor").list();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            //tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
        return result;
    }

    public List<Proveedor> obtenerTodosAGrid(String ordenarPor, String ordenarAsc) {
        List<Proveedor> result = null;
        try {
            this.iniciaOperacion();
            Criteria criteria = session.createCriteria(Proveedor.class);
            if (ordenarAsc.equalsIgnoreCase("asc")) {
                criteria.addOrder(Order.asc(ordenarPor));
            } else if (ordenarAsc.equalsIgnoreCase("desc")) {
                criteria.addOrder(Order.desc(ordenarPor));
            }
            result = criteria.list();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
        return result;
    }

    public Proveedor obtenerProveedorNombre(String nombreProveedor) {
        Proveedor proveedor = null;
        try {
            this.iniciaOperacion();
            Criteria criteria = session.createCriteria(Proveedor.class)
                    .add(Restrictions.eq("nombreProveedor", nombreProveedor));
            proveedor = (Proveedor) criteria.uniqueResult();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            //tx.rollback();
            throw he;
        } finally {
            // Cerrar la session
        }
        return proveedor;
    }

    public List<Proveedor> obtenerNombresProveedores() throws HibernateException {
        List<Proveedor> lista = null;
        try {
            this.iniciaOperacion();
            Query consulta = session.createQuery("SELECT p.id, p.nombreProveedor FROM Proveedor p");
            lista = consulta.list();
        } catch (HibernateException he) {
            Logger.getLogger(ProveedorDAOImpl.class.getName()).log(Level.SEVERE, null, he);
            throw he;
        } finally {
            // Cerrar la session
        }
        return lista;
    }

    // Inicia una transaccion contra la base de datos.
    private void iniciaOperacion() throws HibernateException {
        session = this.getHibernateTemplate().getSessionFactory().openSession();
        tx = session.beginTransaction();
    }

    // Encargado de manejar las excepciones si ocurre algo cuando se conecta a la base de datos
    private void manejaExcepcion(HibernateException he) throws HibernateException {
        tx.rollback();
        throw new HibernateException("Ocurri un error en la capa de acceso a datos", he);
    }

}