All Downloads are FREE. Search and download functionalities are using the official Maven repository.

it.cnr.contab.prevent01.consultazioni.comp.ConsPDGPFoComponent Maven / Gradle / Ivy


/*
 * Copyright (C) 2019  Consiglio Nazionale delle Ricerche
 *
 *     This program is free software: you can redistribute it and/or modify
 *     it under the terms of the GNU Affero General Public License as
 *     published by the Free Software Foundation, either version 3 of the
 *     License, or (at your option) any later version.
 *
 *     This program is distributed in the hope that it will be useful,
 *     but WITHOUT ANY WARRANTY; without even the implied warranty of
 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *     GNU Affero General Public License for more details.
 *
 *     You should have received a copy of the GNU Affero General Public License
 *     along with this program.  If not, see .
 */

package it.cnr.contab.prevent01.consultazioni.comp;

import it.cnr.contab.config00.pdcfin.bulk.Elemento_voceHome;
import it.cnr.contab.config00.sto.bulk.Unita_organizzativaBulk;
import it.cnr.contab.config00.sto.bulk.Unita_organizzativa_enteBulk;
import it.cnr.contab.prevent01.bulk.Pdg_modulo_costiBulk;
import it.cnr.contab.prevent01.consultazioni.bp.ConsPDGPFoBP;
import it.cnr.contab.prevent01.consultazioni.bulk.V_cons_pdgp_foBulk;
import it.cnr.contab.utenze00.bp.CNRUserContext;
import it.cnr.jada.UserContext;
import it.cnr.jada.action.BusinessProcessException;
import it.cnr.jada.bulk.BulkHome;
import it.cnr.jada.bulk.OggettoBulk;
import it.cnr.jada.comp.CRUDComponent;
import it.cnr.jada.persistency.IntrospectionException;
import it.cnr.jada.persistency.PersistencyException;
import it.cnr.jada.persistency.sql.ColumnMap;
import it.cnr.jada.persistency.sql.CompoundFindClause;
import it.cnr.jada.persistency.sql.SQLBuilder;
import it.cnr.jada.persistency.sql.SimpleFindClause;
import it.cnr.jada.util.RemoteIterator;

/**
 * @author rp
 *
 * To change the template for this generated type comment go to
 * Window>Preferences>Java>Code Generation>Code and Comments
 */
public class ConsPDGPFoComponent extends CRUDComponent {
	
		public RemoteIterator findConsultazioneEtr(UserContext userContext, String pathDestinazione, String livelloDestinazione, CompoundFindClause baseClause, CompoundFindClause findClause) throws it.cnr.jada.comp.ComponentException {
			return findConsultazioneDettaglio(userContext, pathDestinazione, livelloDestinazione, baseClause, findClause, null);
		}

		public RemoteIterator findConsultazioneSpe(UserContext userContext, String pathDestinazione, String livelloDestinazione, CompoundFindClause baseClause, CompoundFindClause findClause) throws it.cnr.jada.comp.ComponentException {
			return findConsultazioneDettaglio(userContext, pathDestinazione, livelloDestinazione, baseClause, findClause, null);
		}

		private RemoteIterator findConsultazioneDettaglio(UserContext userContext, String pathDestinazione, String livelloDestinazione, CompoundFindClause baseClause, CompoundFindClause findClause, String tipoCons) throws it.cnr.jada.comp.ComponentException {
			try{
				String cd_unita_organizzativa = it.cnr.contab.utenze00.bp.CNRUserContext.getCd_unita_organizzativa(userContext);
				Unita_organizzativaBulk 	uoScrivania = (Unita_organizzativaBulk) getHome(userContext,Unita_organizzativaBulk.class).findByPrimaryKey(new Unita_organizzativaBulk(cd_unita_organizzativa));
				Unita_organizzativa_enteBulk ente = (Unita_organizzativa_enteBulk) getHomeCache(userContext).getHome(Unita_organizzativa_enteBulk.class).findAll().get(0);
				BulkHome home = getHome(userContext, V_cons_pdgp_foBulk.class, pathDestinazione);
				SQLBuilder sql = home.createSQLBuilder();
				SQLBuilder sqlEsterna = home.createSQLBuilder();
				String tabAlias = sql.getColumnMap().getTableName();
			    if (!((CNRUserContext) userContext).getCd_unita_organizzativa().equals( ente.getCd_unita_organizzativa())){			
				   sql.addSQLClause("AND","SUBSTR(CD_CENTRO_RESPONSABILITA,1,3)",SQLBuilder.EQUALS,CNRUserContext.getCd_cds(userContext));
				   if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_CDR)>=0)
				       sqlEsterna.addSQLClause("AND","SUBSTR(CD_CENTRO_RESPONSABILITA,1,3)",SQLBuilder.EQUALS,CNRUserContext.getCd_cds(userContext));
			    }
			    if(!uoScrivania.isUoCds()){
				   sql.addSQLClause("AND","SUBSTR(CD_CENTRO_RESPONSABILITA,1,7)",SQLBuilder.EQUALS,uoScrivania.getCd_unita_organizzativa());
				   if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_CDR)>=0)
				      sqlEsterna.addSQLClause("AND","SUBSTR(CD_CENTRO_RESPONSABILITA,1,7)",SQLBuilder.EQUALS,uoScrivania.getCd_unita_organizzativa());
			    }
				addBaseColumns(userContext,sql, sqlEsterna, tabAlias, pathDestinazione, livelloDestinazione);
				return iterator(userContext,completaSQL(sql,sqlEsterna,tabAlias,baseClause,findClause),V_cons_pdgp_foBulk.class,null);
			} catch (PersistencyException e) {
				throw new it.cnr.jada.comp.ComponentException(e);
			}		
		}
		/**
		 * Costruisce l'SQLBuilder individuando i campi da ricercare sulla base del path della  consultazione 
		 *  indicata. 
		 *
		 * @param sql la select principale contenente le Sum e i GroupBy
		 * @param sqlEsterna la select esterna necessaria per interrogare la select principale come view
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param pathDestinazione il path completo della mappa di consultazione che ha effettuato la richiesta 
		 * @param livelloDestinazione il livello della mappa di consultazione che ha effettuato la richiesta 
		 */
	private void addBaseColumns(UserContext context,SQLBuilder sql, SQLBuilder sqlEsterna, String tabAlias, String pathDestinazione, String livelloDestinazione) throws it.cnr.jada.comp.ComponentException {
			sql.resetColumns();
			sqlEsterna.resetColumns();
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_TIP)>=0){	
				addColumnTIP(sql,tabAlias,(livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_ETRTIP)||livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_SPETIP)),true,livelloDestinazione);
				addColumnTIP(sqlEsterna,tabAlias,(livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_ETRTIP)||livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_SPETIP)),false,livelloDestinazione);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_CDR)>=0){
				addColumnCDR(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_CDR),true);
				addColumnCDR(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_CDR),false);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_MOD)>=0){
				addColumnMOD(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_MOD),true);
				addColumnMOD(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_MOD),false);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_PRG)>=0){
				addColumnPRG(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_PRG),true);
				addColumnPRG(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_PRG),false);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_LIV1)>=0){
				addColumnLIV1(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV1),true,pathDestinazione,context);
				addColumnLIV1(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV1),false,pathDestinazione,context);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_LIV2)>=0){
				addColumnLIV2(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV2),true);
				addColumnLIV2(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV2),false);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_LIV3)>=0){
				addColumnLIV3(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV3),true);
				addColumnLIV3(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_LIV3),false);
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_DET)>=0){
				addColumnDET(sql,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_DET),true,pathDestinazione);
				addColumnDET(sqlEsterna,tabAlias,livelloDestinazione.equals(ConsPDGPFoBP.LIVELLO_DET),false,pathDestinazione);
			}	
	}			

		/**
		 * Individua e completa l'SQLBuilder da utilizzare:
		 * 1) è stata effettuata una ricerca mirata ( != null)
		 * 	  la select finale è costruita come interrogazione di una view costruita sulla select principale 
		 * 2) non è stata fatta una ricerca mirata
		 * 	  la select finale è uguale alla select principale
		 *
		 * @param sql la select principale contenente le Sum e i GroupBy
		 * @param sqlEsterna la select esterna necessaria per interrogare la select principale come view
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param baseClause la condizione principale non proveniente dall'utente
		 * @param findClause la condizione secondaria proveniente dall'utente tramite la mappa di ricerca guidata
		 * @return SQLBuilder la query da effettuare
		 */
		private SQLBuilder completaSQL(SQLBuilder sql, SQLBuilder sqlEsterna, String tabAlias, CompoundFindClause baseClause, CompoundFindClause findClause){ 
			sql.addClause(baseClause);		
			if (findClause == null) 
			{
				addColumnIMPORTI(sql,tabAlias,true);
				return sql;
			}
			else
			{
				addColumnIMPORTI(sql,tabAlias,true);		
				addColumnIMPORTI(sqlEsterna,tabAlias,false);		
				sqlEsterna.setFromClause(new StringBuffer("(".concat(sql.toString().concat(") ".concat(tabAlias)))));
				sqlEsterna.addClause(findClause);
				return sqlEsterna;
			}
		}

		/**
		 * Aggiunge nell'SQLBuilder  le colonne importo.
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param isSommatoria se TRUE aggiunge la SUM delle colonne
		 */
		private void addColumnIMPORTI(SQLBuilder sql, String tabAlias, boolean isSommatoria) { 
			tabAlias = getAlias(tabAlias);
		if (tabAlias.indexOf("V_CONS_PDG_ETR_BIL_IST_DIP_FO")>=0){
			if (isSommatoria) 
			{
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_IST_A1),0)")), "TOT_ENT_IST_A1");
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_IST_A2),0)")), "TOT_ENT_IST_A2");
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_IST_A3),0)")), "TOT_ENT_IST_A3");
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_AREE_A1),0)")), "TOT_ENT_AREE_A1");
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_AREE_A2),0)")), "TOT_ENT_AREE_A2");
				sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TOT_ENT_AREE_A3),0)")), "TOT_ENT_AREE_A3");
				sql.addColumn("NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_IST_A1,0)),0)+NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_AREE_A1,0)),0)")))), "TOT_ENT_A1");
				sql.addColumn("NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_IST_A2,0)),0)+NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_AREE_A2,0)),0)")))), "TOT_ENT_A2");
				sql.addColumn("NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_IST_A3,0)),0)+NVL(SUM(nvl(".concat(tabAlias.concat("TOT_ENT_AREE_A3,0)),0)")))), "TOT_ENT_A3");
			}
			else
			{
				sql.addColumn("NVL(TOT_ENT_IST_A1,0)", "TOT_ENT_IST_A1");
				sql.addColumn("NVL(TOT_ENT_IST_A2,0)", "TOT_ENT_IST_A2");
				sql.addColumn("NVL(TOT_ENT_IST_A3,0)", "TOT_ENT_IST_A3");
				sql.addColumn("NVL(TOT_ENT_AREE_A1,0)", "TOT_ENT_AREE_A1");
				sql.addColumn("NVL(TOT_ENT_AREE_A2,0)", "TOT_ENT_AREE_A2");
				sql.addColumn("NVL(TOT_ENT_AREE_A3,0)", "TOT_ENT_AREE_A3");
				sql.addColumn("NVL(TOT_ENT_A1,0)", "TOT_ENT_A1");
				sql.addColumn("NVL(TOT_ENT_A2,0)", "TOT_ENT_A2");
				sql.addColumn("NVL(TOT_ENT_A3,0)", "TOT_ENT_A3");
			}
		}
		else{		
				if (isSommatoria) 
				{
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_INT),0)")), "IM_DEC_IST_INT");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_EST),0)")), "IM_DEC_IST_EST");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_INT),0)")), "IM_DEC_AREA_INT");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_EST),0)")), "IM_DEC_AREA_EST");
					sql.addColumn("NVL(SUM(nvl(".concat(tabAlias.concat("IM_DEC_IST_INT,0)),0)+NVL(SUM(nvl(".concat(tabAlias.concat("IM_DEC_AREA_INT,0)),0)")))), "IMP_TOT_DEC_INT");
					sql.addColumn("NVL(SUM(nvl(".concat(tabAlias.concat("IM_DEC_IST_EST,0)),0)+NVL(SUM(nvl(".concat(tabAlias.concat("IM_DEC_AREA_EST,0)),0)")))), "IMP_TOT_DEC_EST");
					
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_EST),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_INT),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_INT),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_EST),0)")))))))), "IMP_TOT_DECENTRATO");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TRATT_ECON_INT),0)")), "TRATT_ECON_INT");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TRATT_ECON_EST),0)")), "TRATT_ECON_EST");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_ACC_ALTRE_SP_INT),0)")), "IM_ACC_ALTRE_SP_INT");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TRATT_ECON_EST),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_EST),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_EST),0)")))))), "IMP_TOT_COMP_EST");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("TRATT_ECON_INT),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_IST_INT),0)+NVL(SUM(".concat(tabAlias.concat("IM_DEC_AREA_INT),0)+NVL(SUM(".concat(tabAlias.concat("IM_ACC_ALTRE_SP_INT),0)")))))))), "IMP_TOT_COMP_INT");
					
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_PREV_A2),0)")), "IM_PREV_A2");
					sql.addColumn("NVL(SUM(".concat(tabAlias.concat("IM_PREV_A3),0)")), "IM_PREV_A3");
				}
				else
				{
					sql.addColumn("NVL(IM_DEC_IST_INT,0)", "IM_DEC_IST_INT");
					sql.addColumn("NVL(IM_DEC_IST_EST,0)", "IM_DEC_IST_EST");
					sql.addColumn("NVL(IM_DEC_AREA_INT,0)", "IM_DEC_AREA_INT");
					sql.addColumn("NVL(IM_DEC_AREA_EST,0)", "IM_DEC_AREA_EST");
					sql.addColumn("NVL(IMP_TOT_DEC_INT,0)", "IMP_TOT_DEC_INT");
					sql.addColumn("NVL(IMP_TOT_DEC_EST,0)", "IMP_TOT_DEC_EST");
					sql.addColumn("NVL(IMP_TOT_DECENTRATO,0)", "IMP_TOT_DECENTRATO");
					sql.addColumn("NVL(TRATT_ECON_INT,0)", "TRATT_ECON_INT");
					sql.addColumn("NVL(TRATT_ECON_EST,0)", "TRATT_ECON_EST");
					sql.addColumn("NVL(IM_ACC_ALTRE_SP_INT,0)", "IM_ACC_ALTRE_SP_INT");
					sql.addColumn("NVL(IMP_TOT_COMP_INT,0)", "IMP_TOT_COMP_INT");
					sql.addColumn("NVL(IMP_TOT_COMP_EST,0)", "IMP_TOT_COMP_EST");
					sql.addColumn("NVL(IM_PREV_A2,0)", "IM_PREV_A2");
					sql.addColumn("NVL(IM_PREV_A3,0)", "IM_PREV_A3");
				}
		}
	}

		/**
		 * Aggiunge nell'SQLBuilder  le colonne del Cdr.
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnCDR(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL){ 
			tabAlias = getAlias(tabAlias);
				addColumn(sql,tabAlias.concat("CD_CENTRO_RESPONSABILITA"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_centro_responsabilita"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_CDR"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_cdr"),isBaseSQL&&addDescrizione);					
		}
		private void addColumnTIP(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL,String livello_arrivo){ 
				tabAlias = getAlias(tabAlias);
				addColumn(sql,tabAlias.concat("ESERCIZIO"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("esercizio"),isBaseSQL);
				addColumn(sql,tabAlias.concat("CD_TIPO_MODULO"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_tipo_modulo"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_TIPO_MODULO"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_tipo_modulo"),isBaseSQL&&addDescrizione);				
				if (tabAlias.indexOf("V_CONS_PDG_SPE_BIL_IST_DIP_FO")>=0 && livello_arrivo.compareTo(ConsPDGPFoBP.LIVELLO_SPETIP)==0){			
					if (isBaseSQL){
						addColumn(sql,		  "(select sum(NVL(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_I,0)+ " +
											  "		       NVL(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_II,0)) " +
											  " From PDG_MODULO_COSTI,PROGETTO "+ 
											  " WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO "+
											  "   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
					   						  "   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO)IM_PRESUNTI_PREC",true);
						addColumn(sql,"(select sum((NVL(PDG_MODULO_COSTI.IM_CF_TFR,0) + "+
									  "             NVL(PDG_MODULO_COSTI.IM_CF_AMM_IMMOBILI,0)+ "+
									  "             NVL(PDG_MODULO_COSTI.IM_CF_AMM_ATTREZZ,0)+" + 
									  "             NVL(PDG_MODULO_COSTI.IM_CF_AMM_ALTRO,0))) "+
									  " From PDG_MODULO_COSTI,PROGETTO "+ 
									  " WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO "+
									  "   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
									  "   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO ) IM_COSTI_FIGURATIVI",true);
						addColumn(sql,"(select sum(NVL(PDG_MODULO_COSTI.IM_COSTI_GENERALI,0)) "+
									  " From PDG_MODULO_COSTI,PROGETTO "+ 
									  " WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO "+
									  "   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
								      "   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO) IM_COSTI_GENERALI",true);
									  
					}
					else
					{
						addColumn(sql,tabAlias.concat("IM_PRESUNTI_PREC"),true);
						addColumn(sql,tabAlias.concat("IM_COSTI_FIGURATIVI"),true);
						addColumn(sql,tabAlias.concat("IM_COSTI_GENERALI"),true);	
					}	
			}					
		}
		/**
		 * Aggiunge nell'SQLBuilder  le colonne Modulo
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnMOD(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL){ 
			tabAlias = getAlias(tabAlias);
			addColumn(sql,tabAlias.concat("CD_MODULO"),true);
			addColumn(sql,tabAlias.concat("DS_MODULO"),addDescrizione);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_modulo"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_modulo"),isBaseSQL&&addDescrizione);
		}
		/**
		 * Aggiunge nell'SQLBuilder  le colonne Progettp
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnPRG(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL){ 
			tabAlias = getAlias(tabAlias);
			addColumn(sql,tabAlias.concat("CD_COMMESSA"),true);
			addColumn(sql,tabAlias.concat("DS_COMMESSA"),addDescrizione);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_commessa"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_commessa"),isBaseSQL&&addDescrizione);
		}
		/**
		 * Aggiunge nell'SQLBuilder  le colonne del primo livello della classificazione.
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnLIV1(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL,String livello_arrivo,UserContext context) throws it.cnr.jada.comp.ComponentException{ 
			tabAlias = getAlias(tabAlias);
			addColumn(sql,tabAlias.concat("CD_LIVELLO1"),true);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_livello1"),isBaseSQL);
			if (isBaseSQL && addDescrizione) {
				sql.addTableToHeader("CLASSIFICAZIONE_VOCI");
				addColumn(sql,"CLASSIFICAZIONE_VOCI.DS_CLASSIFICAZIONE",true);
				addSQLGroupBy(sql,"classificazione_voci.ds_classificazione",true);

				sql.addSQLJoin(tabAlias.concat("ESERCIZIO"),"CLASSIFICAZIONE_VOCI.ESERCIZIO");
				if (sql.getColumnMap().getTableName().equals("V_CONS_PDG_ETR_BIL_IST_DIP_FO"))
					sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_ENTRATE);
				else
					sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_SPESE);
			
				sql.addSQLJoin(tabAlias.concat("CD_LIVELLO1"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO1");
				sql.addSQLClause("AND", "CLASSIFICAZIONE_VOCI.CD_LIVELLO2",sql.ISNULL,null);
			}
			else
				addColumn(sql,tabAlias.concat("DS_CLASSIFICAZIONE"),addDescrizione);

			if (tabAlias.indexOf("V_CONS_PDG_SPE_BIL_IST_DIP_FO")>=0 && livello_arrivo.endsWith(ConsPDGPFoBP.LIVELLO_TIP.concat(ConsPDGPFoBP.LIVELLO_LIV1)) &&isBaseSQL){
									
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'1'","(".concat("select sum(NVL(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_I,0)) "+
													" From PDG_MODULO_COSTI,PROGETTO "+ 
													" WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO " +
				  									"   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
				  									"   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO ").concat(")"),
										"'2'","(".concat("select sum(NVL(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_II,0)) "+
												" From PDG_MODULO_COSTI,PROGETTO "+ 
												" WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO " +
												"   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
												"   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO ").concat(")"),"0").concat(" IM_PRESUNTI_PREC"),true);
					
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'2'","(".concat("select nvl(sum(NVL(PDG_MODULO_COSTI.IM_CF_TFR,0) + "+ 
												"   NVL(PDG_MODULO_COSTI.IM_CF_AMM_IMMOBILI,0)+ "+
												"   NVL(PDG_MODULO_COSTI.IM_CF_AMM_ATTREZZ,0)+" + 
												"   NVL(PDG_MODULO_COSTI.IM_CF_AMM_ALTRO,0)),0)" +
												" 	From PDG_MODULO_COSTI,PROGETTO "+ 
												" 	WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO " +
												"   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
												"   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO ").concat(")"),
									null,null,"0").concat(" IM_COSTI_FIGURATIVI"), true);
				
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'2'","(".concat("select nvl(SUM(nvl(PDG_MODULO_COSTI.IM_COSTI_GENERALI,0)),0)"+
												" 	From PDG_MODULO_COSTI,PROGETTO "+ 
												" 	WHERE V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO=PDG_MODULO_COSTI.ESERCIZIO " +
												"   And PROGETTO.PG_PROGETTO = PDG_MODULO_COSTI.PG_PROGETTO "+
												"   And PROGETTO.CD_TIPO_PROGETTO = V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_TIPO_MODULO ").concat(")"),null,null,"0").concat(" IM_COSTI_GENERALI"), true);
																			  
			}else if (tabAlias.indexOf("V_CONS_PDG_SPE_BIL_IST_DIP_FO")>=0 && 
					(livello_arrivo.endsWith(ConsPDGPFoBP.LIVELLO_MOD.concat(ConsPDGPFoBP.LIVELLO_LIV1)) || 
					 livello_arrivo.endsWith(ConsPDGPFoBP.LIVELLO_PRG.concat(ConsPDGPFoBP.LIVELLO_LIV1))) &&isBaseSQL){
						BulkHome home;
						home = getHome(context, Pdg_modulo_costiBulk.class);
						SQLBuilder sqlsum = home.createSQLBuilder();
						sqlsum.resetColumns();
						sqlsum.addColumn("SUM(nvl(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_I,0))");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO","PDG_MODULO_COSTI.ESERCIZIO");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_CENTRO_RESPONSABILITA","PDG_MODULO_COSTI.CD_CENTRO_RESPONSABILITA");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.PG_MODULO","PDG_MODULO_COSTI.PG_PROGETTO(+)");
						SQLBuilder sqlsum2 = home.createSQLBuilder();
						sqlsum2.resetColumns();
						sqlsum2.addColumn("SUM(nvl(PDG_MODULO_COSTI.RIS_PRES_ES_PREC_TIT_II,0))");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO","PDG_MODULO_COSTI.ESERCIZIO");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_CENTRO_RESPONSABILITA","PDG_MODULO_COSTI.CD_CENTRO_RESPONSABILITA");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.PG_MODULO","PDG_MODULO_COSTI.PG_PROGETTO(+)");
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'1'","(".concat(sqlsum.toString()).concat(")"),"'2'","(".concat(sqlsum2.toString()).concat(")"),"0").concat(" IM_PRESUNTI_PREC"), true);
					
						sqlsum.resetColumns();
						sqlsum.addColumn("nvl(sum(NVL(PDG_MODULO_COSTI.IM_CF_TFR,0) + "+
										  "    NVL(PDG_MODULO_COSTI.IM_CF_AMM_IMMOBILI,0)+ "+
										  "    NVL(PDG_MODULO_COSTI.IM_CF_AMM_ATTREZZ,0)+" + 
										  "    NVL(PDG_MODULO_COSTI.IM_CF_AMM_ALTRO,0)),0)");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO","PDG_MODULO_COSTI.ESERCIZIO");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_CENTRO_RESPONSABILITA","PDG_MODULO_COSTI.CD_CENTRO_RESPONSABILITA");
						sqlsum.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.PG_MODULO","PDG_MODULO_COSTI.PG_PROGETTO(+)");
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'2'","(".concat(sqlsum.toString()).concat(")"),null,null,"0").concat(" IM_COSTI_FIGURATIVI"), true);
						
						sqlsum2.resetColumns();
						sqlsum2.addColumn("nvl(SUM(nvl(PDG_MODULO_COSTI.IM_COSTI_GENERALI,0)),0)");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.ESERCIZIO","PDG_MODULO_COSTI.ESERCIZIO");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_CENTRO_RESPONSABILITA","PDG_MODULO_COSTI.CD_CENTRO_RESPONSABILITA");
						sqlsum2.addSQLJoin("V_CONS_PDG_SPE_BIL_IST_DIP_FO.PG_MODULO","PDG_MODULO_COSTI.PG_PROGETTO(+)");
						addColumn(sql,sql.addDecode("V_CONS_PDG_SPE_BIL_IST_DIP_FO.CD_LIVELLO1","'2'","(".concat(sqlsum2.toString()).concat(")"),null,null,"0").concat(" IM_COSTI_GENERALI"), true);
						addSQLGroupBy(sql,"V_CONS_PDG_SPE_BIL_IST_DIP_FO.PG_MODULO",true);
			}
			else if (tabAlias.indexOf("V_CONS_PDG_SPE_BIL_IST_DIP_FO")>=0 &&  livello_arrivo.endsWith(ConsPDGPFoBP.LIVELLO_LIV1))
			{
			  addColumn(sql,tabAlias.concat("IM_PRESUNTI_PREC"),true);
			  addColumn(sql,tabAlias.concat("IM_COSTI_FIGURATIVI"),true);
			  addColumn(sql,tabAlias.concat("IM_COSTI_GENERALI"),true);	
			}	
		}
		/**
		 * Aggiunge nell'SQLBuilder  le colonne del secondo livello della classificazione.
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnLIV2(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL){ 
			tabAlias = getAlias(tabAlias);
			addColumn(sql,tabAlias.concat("CD_LIVELLO2"),true);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_livello2"),isBaseSQL);
			if (isBaseSQL && addDescrizione) {
				sql.addTableToHeader("CLASSIFICAZIONE_VOCI");
				addColumn(sql,"CLASSIFICAZIONE_VOCI.DS_CLASSIFICAZIONE",true);
				sql.addSQLGroupBy("classificazione_voci.ds_classificazione");
				sql.addSQLJoin(tabAlias.concat("ESERCIZIO"),"CLASSIFICAZIONE_VOCI.ESERCIZIO");
				if (sql.getColumnMap().getTableName().equals("V_CONS_PDG_ETR_BIL_IST_DIP_FO"))
					sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_ENTRATE);
				else
					sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_SPESE);
			
				sql.addSQLJoin(tabAlias.concat("CD_LIVELLO1"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO1");
				sql.addSQLJoin(tabAlias.concat("CD_LIVELLO2"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO2");
				sql.addSQLClause("AND", "CLASSIFICAZIONE_VOCI.CD_LIVELLO3",sql.ISNULL,null);
			}
			else
				addColumn(sql,"DS_CLASSIFICAZIONE",addDescrizione);
		}
		
		private void addColumnLIV3(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL){ 
				tabAlias = getAlias(tabAlias);
				addColumn(sql,tabAlias.concat("CD_LIVELLO3"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_livello3"),isBaseSQL);
				if (isBaseSQL && addDescrizione) {
					sql.addTableToHeader("CLASSIFICAZIONE_VOCI");
					addColumn(sql,"CLASSIFICAZIONE_VOCI.DS_CLASSIFICAZIONE",true);
					sql.addSQLGroupBy("classificazione_voci.ds_classificazione");
					sql.addSQLJoin(tabAlias.concat("ESERCIZIO"),"CLASSIFICAZIONE_VOCI.ESERCIZIO");
					if (sql.getColumnMap().getTableName().equals("V_CONS_PDG_ETR_BIL_IST_DIP_FO"))
						sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_ENTRATE);
					else
						sql.addSQLClause("AND","CLASSIFICAZIONE_VOCI.TI_GESTIONE",sql.EQUALS,Elemento_voceHome.GESTIONE_SPESE);
			
					sql.addSQLJoin(tabAlias.concat("CD_LIVELLO1"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO1");
					sql.addSQLJoin(tabAlias.concat("CD_LIVELLO2"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO2");
					sql.addSQLJoin(tabAlias.concat("CD_LIVELLO3"),"CLASSIFICAZIONE_VOCI.CD_LIVELLO3");
					sql.addSQLClause("AND", "CLASSIFICAZIONE_VOCI.CD_LIVELLO4",sql.ISNULL,null);
				}
				else
					addColumn(sql,"DS_CLASSIFICAZIONE",addDescrizione);
			}
		/**
		 * Aggiunge nell'SQLBuilder  le colonne del dettaglio ultimo della Consultazione.
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param tabAlias l'alias della tabella da aggiungere alle colonne interrogate
		 * @param addDescrizione se TRUE aggiunge anche la colonna della Descrizione
		 * @param isBaseSQL indica se il parametro sql indicato è l'SQLBuilder principale
		 * 		  (necessario perchè solo per l'SQLBuilder principale occorre aggiungere i GroupBy) 
		 */
		private void addColumnDET(SQLBuilder sql, String tabAlias, boolean addDescrizione, boolean isBaseSQL,String pathDestinazione){ 
			tabAlias = getAlias(tabAlias);
			addColumn(sql,tabAlias.concat("CD_DIPARTIMENTO"),true);
			addColumn(sql,tabAlias.concat("DS_DIPARTIMENTO"),addDescrizione);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_dipartimento"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_dipartimento"),isBaseSQL&&addDescrizione);
			addColumn(sql,tabAlias.concat("PG_PROGETTO"),true);
			addColumn(sql,tabAlias.concat("CD_PROGETTO"),true);
			addColumn(sql,tabAlias.concat("DS_PROGETTO"),addDescrizione);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("pg_progetto"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_progetto"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_progetto"),isBaseSQL&&addDescrizione);
			addColumn(sql,tabAlias.concat("CD_COMMESSA"),true);
			addColumn(sql,tabAlias.concat("DS_COMMESSA"),addDescrizione);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_commessa"),isBaseSQL);
			addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_commessa"),isBaseSQL&&addDescrizione);
							
			if (tabAlias.indexOf("V_CONS_PDG_ETR_BIL_IST_DIP_FO")>=0){
				addColumn(sql,tabAlias.concat("CD_TERZO_FINANZIATORE"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_terzo_finanziatore"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_DETTAGLIO"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_dettaglio"),isBaseSQL);
				addColumn(sql,tabAlias.concat("TOT_FINANZIAMENTO"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("tot_finanziamento"),isBaseSQL);
				addColumn(sql,tabAlias.concat("CD_CLASSIFICAZIONE"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_classificazione"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_CLASSIFICAZIONE"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_classificazione"),isBaseSQL&&addDescrizione);
			}	else
			{
				addColumn(sql,tabAlias.concat("CD_CLASSIFICAZIONE"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_classificazione"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_CLASSIFICAZIONE"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_classificazione"),isBaseSQL&&addDescrizione);	
			}
			if (pathDestinazione.indexOf(ConsPDGPFoBP.LIVELLO_CDR)<0)
			{
				addColumn(sql,tabAlias.concat("CD_CENTRO_RESPONSABILITA"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_centro_responsabilita"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_CDR"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_cdr"),isBaseSQL&&addDescrizione);
				addColumn(sql,tabAlias.concat("CD_MODULO"),true);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("cd_modulo"),isBaseSQL);
				addColumn(sql,tabAlias.concat("DS_MODULO"),addDescrizione);
				addSQLGroupBy(sql,tabAlias.toLowerCase().concat("ds_modulo"),isBaseSQL&&addDescrizione);				
			}	
		}
		/**
		 * Ritorna l'alias della tabella da aggiungere alle colonne di una select.
		 * Viene verificato il parametro  indicato
		 * 1) se null ritorna null;
		 * 2) se pieno concatena "."
		 *
		 * @param alias l'alias da aggiornare per aggiungerlo alle colonne di una select.
		 * @return l'alias da utilizzare nella select.
		 */
		private String getAlias(String alias){ 
			if (alias == null) return new String("");
			if (alias.equals(new String(""))) return new String("");
			return new String(alias.concat("."));
		}
		/**
		 * Aggiunge nel GroupBy dell'SQLBuilder  indicato il valore 
		 *
		 * @param sql l'SQLBuilder da aggiornare.
		 * @param valore il valore da aggiungere al GroupBy.
		 * @param addGroupBy se TRUE aggiunge il valore. Se FALSE non effettua alcuna istruzione.
		 */
		private void addSQLGroupBy(SQLBuilder sql, String valore, boolean addGroupBy){
			if (addGroupBy)
				sql.addSQLGroupBy(valore);
		}
		/**
		 * Aggiunge nella lista delle colonne da interrogare dell'SQLBuilder  indicato il valore 
		 *
		 * @param sql l'SQLBuilder da aggiornare
		 * @param valore il valore da aggiungere alla lista delle colonne da interrogare.
		 * @param addColumn se TRUE aggiunge il valore. Se FALSE non effettua alcuna istruzione.
		 */
		private void addColumn(SQLBuilder sql, String valore, boolean addColumn){
			if (addColumn)
				sql.addColumn(valore);
		}
	}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy