package br.com.centralit.citcorpore.integracao; import java.util.ArrayList; import java.util.Collection; import java.util.List; import br.com.centralit.citcorpore.bean.GrupoRequisicaoMudancaDTO; import br.com.citframework.dto.IDto; import br.com.citframework.excecao.PersistenceException; import br.com.citframework.integracao.Condition; import br.com.citframework.integracao.CrudDaoDefaultImpl; import br.com.citframework.integracao.Field; import br.com.citframework.integracao.Order; import br.com.citframework.util.Constantes; /** * @author mario.haysaki * */ public class GrupoRequisicaoMudancaDao extends CrudDaoDefaultImpl { public GrupoRequisicaoMudancaDao() { super(Constantes.getValue("DATABASE_ALIAS"), null); } @Override public Collection find(final IDto obj) throws PersistenceException { final List<Order> order = new ArrayList<>(); order.add(new Order("idGrupoRequisicaoMudanca")); return super.find(obj, order); } @Override public Collection<Field> getFields() { final Collection<Field> listFields = new ArrayList<>(); listFields.add(new Field("idgruporequisicaomudanca", "idGrupoRequisicaoMudanca", true, true, false, false)); listFields.add(new Field("idgrupo", "idGrupo", false, false, false, false)); listFields.add(new Field("idrequisicaomudanca", "idRequisicaoMudanca", false, false, false, false)); listFields.add(new Field("nomegrupo", "nomeGrupo", false, false, false, false)); listFields.add(new Field("datafim", "dataFim", false, false, false, false)); return listFields; } @Override public String getTableName() { return this.getOwner() + "gruporequisicaomudanca"; } @Override public Collection list() throws PersistenceException { return super.list("idGrupoRequisicaoMudanca"); } @Override public Class<GrupoRequisicaoMudancaDTO> getBean() { return GrupoRequisicaoMudancaDTO.class; } public Collection findByIdGrupoRequisicaoMudanca(final Integer parm) throws PersistenceException { final List<Condition> condicao = new ArrayList<>(); final List<Order> ordenacao = new ArrayList<>(); condicao.add(new Condition("idGrupoRequisicaoMudanca", "=", parm)); ordenacao.add(new Order("idGrupoRequisicaoMudanca")); return super.findByCondition(condicao, ordenacao); } public void deleteByIdGrupoRequisicaoMudanca(final Integer parm) throws PersistenceException { final List<Condition> condicao = new ArrayList<>(); condicao.add(new Condition("idGrupoRequisicaoMudanca", "=", parm)); super.deleteByCondition(condicao); } public Collection findByIdGrupo(final Integer parm) throws PersistenceException { final List<Condition> condicao = new ArrayList<>(); final List<Order> ordenacao = new ArrayList<>(); condicao.add(new Condition("idGrupo", "=", parm)); ordenacao.add(new Order("idGrupo")); return super.findByCondition(condicao, ordenacao); } public void deleteByIdGrupo(final Integer parm) throws PersistenceException { final List<Condition> condicao = new ArrayList<>(); condicao.add(new Condition("idGrupo", "=", parm)); super.deleteByCondition(condicao); } public Collection findByIdRequisicaoMudanca(final Integer parm) throws PersistenceException { final List<Integer> parametro = new ArrayList<>(); final List<String> fields = new ArrayList<>(); final StringBuilder sql = new StringBuilder(); sql.append(" SELECT distinct grupo.idgrupo, grupo.nomegrupo, grupo.idgruporequisicaomudanca, grupo.idrequisicaomudanca FROM gruporequisicaomudanca grupo "); sql.append(" JOIN requisicaomudanca rm ON grupo.idrequisicaomudanca = rm.idrequisicaomudanca "); sql.append(" WHERE rm.idrequisicaomudanca = ? and grupo.datafim is null ORDER BY grupo.idgrupo "); parametro.add(parm); final List list = this.execSQL(sql.toString(), parametro.toArray()); fields.add("idGrupo"); fields.add("nomeGrupo"); if (list != null && !list.isEmpty()) { return this.listConvertion(this.getBean(), list, fields); } return null; } public Collection findByIdMudancaEDataFim(final Integer idRequisicaoMudanca) throws PersistenceException { final List<String> fields = new ArrayList<>(); final List<Integer> parametro = new ArrayList<>(); final StringBuilder sql = new StringBuilder(); sql.append("select idgruporequisicaomudanca, idgrupo, idrequisicaomudanca, nomegrupo, datafim from gruporequisicaomudanca WHERE idrequisicaomudanca = ? and datafim is null"); parametro.add(idRequisicaoMudanca); final List resultado = this.execSQL(sql.toString(), parametro.toArray()); fields.add("idGrupoRequisicaoMudanca"); fields.add("idGrupo"); fields.add("idRequisicaoMudanca"); fields.add("nomeGrupo"); fields.add("dataFim"); return this.listConvertion(this.getBean(), resultado, fields); } public Collection listByIdHistoricoMudanca(final Integer idHistoricoMudanca) throws PersistenceException { final List<String> fields = new ArrayList<>(); final String sql = "select distinct pr.idproblemamudanca, pr.idproblema, pr.idrequisicaomudanca, pr.datafim from problemamudanca pr " + "inner join ligacao_mud_hist_pr ligpr on ligpr.idproblemamudanca = pr.idproblemamudanca WHERE ligpr.idhistoricomudanca = ?"; final List resultado = this.execSQL(sql, new Object[] {idHistoricoMudanca}); fields.add("idProblemaMudanca"); fields.add("idProblema"); fields.add("idRequisicaoMudanca"); fields.add("dataFim"); return this.listConvertion(this.getBean(), resultado, fields); } public void deleteByIdRequisicaoMudanca(final Integer parm) throws PersistenceException { final List<Condition> condicao = new ArrayList<>(); condicao.add(new Condition("idRequisicaoMudanca", "=", parm)); super.deleteByCondition(condicao); } }