Série para venda embarcada

bug#13748
dev:trevezani
qua:

git-svn-id: http://desenvolvimento.rjconsultores.com.br/repositorio/sco/AdmVenta/Model/trunk/modelWeb@91304 d1611594-4594-4d17-8e1d-87c2c4800839
master
alberto 2019-03-28 14:55:38 +00:00
parent 2232c48237
commit d1615f458f
3 changed files with 101 additions and 9 deletions

View File

@ -4,6 +4,9 @@ import com.rjconsultores.ventaboletos.entidad.CtrlSerieBPe;
public interface CtrlSerieBPeDAO extends GenericDAO<CtrlSerieBPe, Long> { public interface CtrlSerieBPeDAO extends GenericDAO<CtrlSerieBPe, Long> {
public void gerarSeqSerieBPe(Integer empresaId, String estado, Integer minvalue) throws RuntimeException;
public Integer buscarSequencia(Integer empresaId, String estado);
public CtrlSerieBPe buscarPorEmpresaEstado(Integer empresaId, Integer estadoId); public CtrlSerieBPe buscarPorEmpresaEstado(Integer empresaId, Integer estadoId);
} }

View File

@ -1,5 +1,12 @@
package com.rjconsultores.ventaboletos.dao.hibernate; package com.rjconsultores.ventaboletos.dao.hibernate;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.sql.DataSource;
import org.hibernate.Query; import org.hibernate.Query;
import org.hibernate.SessionFactory; import org.hibernate.SessionFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -15,11 +22,88 @@ import com.rjconsultores.ventaboletos.entidad.CtrlSerieBPe;
public class CtrlSerieBPeHibernateDAO extends GenericHibernateDAO<CtrlSerieBPe, Long> implements CtrlSerieBPeDAO { public class CtrlSerieBPeHibernateDAO extends GenericHibernateDAO<CtrlSerieBPe, Long> implements CtrlSerieBPeDAO {
private static final Logger log = LoggerFactory.getLogger(CtrlSerieBPeHibernateDAO.class); private static final Logger log = LoggerFactory.getLogger(CtrlSerieBPeHibernateDAO.class);
@Autowired
private DataSource dataSource;
@Autowired @Autowired
public CtrlSerieBPeHibernateDAO(@Qualifier("sessionFactory") SessionFactory factory) { public CtrlSerieBPeHibernateDAO(@Qualifier("sessionFactory") SessionFactory factory) {
setSessionFactory(factory); setSessionFactory(factory);
} }
public void gerarSeqSerieBPe(Integer empresaId, String estado, Integer minvalue) throws RuntimeException {
Connection conn = null;
try {
conn = dataSource.getConnection();
StringBuilder seq = new StringBuilder();
seq.append("SERIE_BPE_");
seq.append(estado).append("_");
seq.append(empresaId).append("_");
seq.append("SEQ");
if (!conn.createStatement().executeQuery("select SEQUENCE_NAME from DBA_SEQUENCES where SEQUENCE_NAME like '" + seq.toString() + "%'").next()) {
conn.createStatement().execute("CREATE SEQUENCE " + seq.toString() + " MINVALUE 1 MAXVALUE 999 INCREMENT BY 1 START WITH " + minvalue.toString() + " ORDER NOCACHE");
log.info("SEQUENCIA " + seq.toString() + " GERADA COM SUCESSO.");
}
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
try {
if (conn != null && !conn.isClosed()) {
conn.close();
}
} catch (SQLException e) {
log.error(e.getMessage(), e);
}
}
}
public Integer buscarSequencia(Integer empresaId, String estado) {
Integer retorno = null;
Connection conn = null;
Statement st = null;
ResultSet rs = null;
try {
conn = dataSource.getConnection();
StringBuilder seq = new StringBuilder();
seq.append("SERIE_BPE_");
seq.append(estado).append("_");
seq.append(empresaId).append("_");
seq.append("SEQ");
StringBuilder sql = new StringBuilder();
sql.append("select ").append(seq.toString()).append(".nextval from dual");
st = conn.createStatement();
rs = st.executeQuery(sql.toString());
rs.next();
retorno = rs.getInt(1);
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
try { if (rs != null) rs.close(); } catch (Exception e) { log.error("", e); }
try { if (st != null) st.close(); } catch (Exception e) { log.error("", e); }
try {
if (conn != null && !conn.isClosed()) {
conn.close();
}
} catch (SQLException e) {
log.error(e.getMessage(), e);
}
}
return retorno;
}
public CtrlSerieBPe buscarPorEmpresaEstado(Integer empresaId, Integer estadoId) { public CtrlSerieBPe buscarPorEmpresaEstado(Integer empresaId, Integer estadoId) {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
sb.append("SELECT ctrl "); sb.append("SELECT ctrl ");

View File

@ -1,7 +1,5 @@
package com.rjconsultores.ventaboletos.service.impl; package com.rjconsultores.ventaboletos.service.impl;
import java.util.Date;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
@ -49,16 +47,23 @@ public class ControleSerieEmbarcadaServiceImpl implements ControleSerieEmbarcada
if (serieembarcada == null) { if (serieembarcada == null) {
CtrlSerieBPe ctrlSerieBpe = ctrlSerieBPeDAO.buscarPorEmpresaEstado(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getEstadoId()); CtrlSerieBPe ctrlSerieBpe = ctrlSerieBPeDAO.buscarPorEmpresaEstado(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getEstadoId());
Integer serie = 0; Integer serie = 1;
if (ctrlSerieBpe != null) { if (ctrlSerieBpe == null) {
serie = Integer.valueOf(ctrlSerieBpe.getSerie()); try {
ctrlSerieBPeDAO.gerarSeqSerieBPe(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getCveestado(), serie);
} catch (Exception e) {
serie = ctrlSerieBPeDAO.buscarSequencia(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getCveestado());
}
} else {
try {
ctrlSerieBPeDAO.gerarSeqSerieBPe(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getCveestado(), Integer.valueOf(ctrlSerieBpe.getSerie()) + 1);
} catch (Exception e) {
}
serie = ctrlSerieBPeDAO.buscarSequencia(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getCveestado());
} }
do {
serie++;
} while (ctrlSerieEmbarcadaDAO.validaPossuiDispositivo(controleSerieEmbarcada.getEmpresa().getEmpresaId(), controleSerieEmbarcada.getEstado().getEstadoId(), serie.toString()));
serieembarcada = new SerieEmbarcada(); serieembarcada = new SerieEmbarcada();
serieembarcada.setSerie(serie.toString()); serieembarcada.setSerie(serie.toString());
serieembarcada.setNumero("1"); serieembarcada.setNumero("1");