com.mx.teknei.pcabordo.lib.dao.impl.RecpNavDAO.java Source code

Java tutorial

Introduction

Here is the source code for com.mx.teknei.pcabordo.lib.dao.impl.RecpNavDAO.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.mx.teknei.pcabordo.lib.dao.impl;

import com.mx.teknei.pcabordo.lib.connection.LoadConnection;
import static com.mx.teknei.pcabordo.lib.connection.LoadConnection.getSessionFactory;
import com.mx.teknei.pcabordo.lib.dao.IRecpNavDAO;
import java.util.ArrayList;
import java.util.List;
import com.mx.teknei.pcabordo.lib.entities.SfmoReceNave;
import com.mx.teknei.pcabordo.lib.logger.Logg;
import org.hibernate.Criteria;
import org.hibernate.NonUniqueResultException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Restrictions;

/**
 *
 * @author HAENCISO
 */
public class RecpNavDAO extends GenericDaoImp<SfmoReceNave, Long> implements IRecpNavDAO {

    @Override
    public List<SfmoReceNave> listRecpNav() {
        List<SfmoReceNave> recpnav = null;
        Transaction trans = null;
        Session session = null;
        try {
            session = LoadConnection.getSessionFactory().openSession();
        } catch (ExceptionInInitializerError eiie) {
            System.out.println("Error al iniciar la coneccion a BD postgres:" + eiie.getMessage());
        } catch (Exception e) {
            System.err.println("Error en LoadConnection." + e.getMessage());
        }
        try {
            trans = session.beginTransaction();
            recpnav = session.createQuery("from SfmoReceNave").list();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            session.flush();
            session.close();
        }

        return recpnav;
    }

    @Override
    public SfmoReceNave findByIdVehi(int idVehi) {
        SfmoReceNave recpnav = null;
        Transaction trans = null;
        Session session = null;
        try {
            session = LoadConnection.getSessionFactory().openSession();
        } catch (ExceptionInInitializerError eiie) {
            System.out.println("Error al iniciar la coneccion a BD postgres:" + eiie.getMessage());
        } catch (Exception e) {
            System.err.println("Error en LoadConnection." + e.getMessage());
        }
        try {
            trans = session.beginTransaction();
            Criteria crit = session.createCriteria(SfmoReceNave.class);
            Criteria vehi = crit.createCriteria("sfvhVehi");
            vehi.add(Restrictions.eq("idVehi", idVehi));
            recpnav = (SfmoReceNave) crit.uniqueResult();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            trans.commit();
            session.flush();
            session.close();
        }

        return recpnav;
    }

    @Override
    public SfmoReceNave lastRecpNav() {
        SfmoReceNave rec_nav = null;
        Transaction trans = null;
        Session session = null;
        try {
            session = LoadConnection.getSessionFactory().openSession();
        } catch (ExceptionInInitializerError eiie) {
            System.out.println("Error al iniciar la coneccion a BD postgres:" + eiie.getMessage());
        } catch (Exception e) {
            System.err.println("Error en LoadConnection." + e.getMessage());
        }
        try {
            trans = session.beginTransaction();
            //            Query queryFindCata = session.createQuery("FROM SfmoReceNave r ORDER BY r.idRecoNave DESC LIMIT 1");
            Query queryFindLastRec = session.createQuery("FROM SfmoReceNave r ORDER BY r.idRecoNave DESC");
            queryFindLastRec.setMaxResults(1);
            queryFindLastRec.setFirstResult(0);
            rec_nav = (SfmoReceNave) queryFindLastRec.uniqueResult();
        } catch (NonUniqueResultException nonE) {
            // Logg.getInstance().fatal( this.getClass().getSimpleName()+"_lastRecpNav_"+"Error No es el unico REGISTRO que regreso la BD_"+nonE.getMessage() );
        } catch (Exception e) {
            // Logg.getInstance().fatal( this.getClass().getSimpleName()+"_lastRecpNav_"+e.getMessage() );
        } finally {
            session.flush();
            session.close();
        }
        if (rec_nav == null) {
            throw new RuntimeException(
                    "NO HAY NINGUNA COORDENADA EN LA BD_" + this.getClass().getSimpleName() + "_lastRecpNav");
        } else {
            return rec_nav;
        }
    }

    @Override
    public SfmoReceNave findByIdRecpNav(int idRecpNav) {
        SfmoReceNave recpnav = null;
        Transaction trans = null;
        Session session = null;
        try {
            session = LoadConnection.getSessionFactory().openSession();
        } catch (ExceptionInInitializerError eiie) {
            System.out.println("Error al iniciar la coneccion a BD postgres:" + eiie.getMessage());
        } catch (Exception e) {
            System.err.println("Error en LoadConnection." + e.getMessage());
        }
        try {
            trans = session.beginTransaction();
            Criteria crit = session.createCriteria(SfmoReceNave.class);
            crit.add(Restrictions.eq("idRecoNave", idRecpNav));
            recpnav = (SfmoReceNave) crit.uniqueResult();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            session.flush();
            session.close();
        }
        return recpnav;
    }

}