AdmMono/src/com/rjconsultores/ventaboletos/dao/hibernate/GP_PricingDiaHibernateDAO.java

73 lines
2.4 KiB
Java

package com.rjconsultores.ventaboletos.dao.hibernate;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import org.apache.log4j.Logger;
import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.Restrictions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Repository;
import com.rjconsultores.ventaboletos.dao.GP_PricingDiaDAO;
import com.rjconsultores.ventaboletos.entidad.GP_Pricing;
import com.rjconsultores.ventaboletos.entidad.GP_PricingDia;
import com.rjconsultores.ventaboletos.entidad.Pricing;
@Repository("gp_pricingDiaDAO")
public class GP_PricingDiaHibernateDAO extends GenericHibernateDAO<GP_PricingDia, Integer>
implements GP_PricingDiaDAO {
private static final Logger log = Logger.getLogger(GP_PricingDiaHibernateDAO.class);
@Autowired
public GP_PricingDiaHibernateDAO(@Qualifier("sessionFactory") SessionFactory factory) {
setSessionFactory(factory);
}
@Override
public List<GP_PricingDia> obtenerTodos() {
Criteria c = getSession().createCriteria(getPersistentClass());
c.add(Restrictions.eq("activo", Pricing.ATIVO));
return c.list();
}
public List<GP_PricingDia> buscarTraslapa(GP_PricingDia pricingDia) {
Date horarioinicio = pricingDia.getHorarioinicio();
Date horariofin = pricingDia.getHorariofin();
SimpleDateFormat sf = new SimpleDateFormat("HHmm");
StringBuilder hql = new StringBuilder();
hql.append("select pv from GP_PricingDia pv ");
hql.append(" where pv.activo = 1 ");
hql.append(" and pricing.pricingId = ").append(pricingDia.getPricing().getPricingId());
hql.append(" and pv.horariofin >= :horariofin ");
hql.append(" and pv.horarioinicio >= :horarioinicio ");
log.info("Hora Ini: " + sf.format(horarioinicio));
log.info("Hora Fin: " + sf.format(horariofin));
log.info("SQL: " + hql.toString());
Query sq = getSession().createQuery(hql.toString());
sq.setParameter("horariofin", horariofin);
sq.setParameter("horarioinicio", horarioinicio);
return sq.list();
}
@Override
public List<GP_PricingDia> obtenerTodoPorPricing(GP_Pricing pricing) {
Criteria c = getSession().createCriteria(getPersistentClass());
c.add(Restrictions.eq("pricing.pricingId", pricing.getPricingId()));
return c.list();
}
}