forked from Coded/SIPRP
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							752 lines
						
					
					
						
							31 KiB
						
					
					
				
			
		
		
	
	
							752 lines
						
					
					
						
							31 KiB
						
					
					
				| /*
 | |
|  * EstatisticasProvider.java
 | |
|  *
 | |
|  * Created on 3 de Junho de 2004, 18:23
 | |
|  */
 | |
| 
 | |
| package siprp.pesquisas;
 | |
| 
 | |
| import java.util.*;
 | |
| 
 | |
| import com.evolute.utils.*;
 | |
| import com.evolute.utils.arrays.*;
 | |
| import com.evolute.utils.data.*;
 | |
| import com.evolute.utils.db.*;
 | |
| import com.evolute.utils.db.keyretrievers.*;
 | |
| import com.evolute.utils.metadb.*;
 | |
| import com.evolute.utils.sql.*;
 | |
| import com.evolute.utils.sql.expression.*;
 | |
| 
 | |
| import siprp.data.*;
 | |
| /**
 | |
|  *
 | |
|  * @author  fpalma
 | |
|  */
 | |
| public class PesquisasProvider extends MetaProvider 
 | |
| {
 | |
| 	private static final Object LOCK = new Object();
 | |
| 	private static PesquisasProvider instance = null;
 | |
| 	private final Executer executer;
 | |
| 	
 | |
| 	private static final int TIPOS_OCASIONAL[] = 
 | |
| 		new int[]{ 5, //mudanca de posto
 | |
| 					6, //mudancas das condicoes
 | |
| 					-1, //apos 30 dias
 | |
| 					4, //iniciativa do medico
 | |
| 					3, //pedido do trabalhador
 | |
| 					2, //acidente de trabalho
 | |
| 					1, //Doenca subita
 | |
| 					-1, //Cessacao do contrato
 | |
| 					10 //Outras razoes
 | |
| 				};
 | |
| 	public static final String DESCRICAO_TIPOS_OCASIONAL[] =
 | |
| 		new String[]{ "MUDAN\u00C7A DE POSTO DE TRABALHO",
 | |
| 						"ALTERA\u00C7\u00D5ES NO POSTO DE TRABALHO",
 | |
| 						"REGRESSO AO TRABALHO AP\u00D3S AUS\u00CANCIA SUPERIOR A 30 DIAS",
 | |
| 						"INICIATIVA DO M\u00C9DICO",
 | |
| 						"PEDIDO DO TRABALHADOR",
 | |
| 						"ACIDENTE DE TRABALHO",
 | |
| 						"DOEN\u00C7A S\u00DABITA",
 | |
| 						"POR CESSA\u00C7\u00C3O DO CONTRATO DE TRABALHO",
 | |
| 						"OUTRAS RAZ\u00D5ES" };
 | |
| 	
 | |
| 	private static final int TIPOS_EXAME[] =
 | |
| 		new int[]{ 1, //admissao
 | |
| 					2, //periodico
 | |
| 					3 //ocasional
 | |
| 				};
 | |
| 	private static final int TIPO_OCASIONAL = 3;
 | |
| 				
 | |
| 	public static final String DESCRICAO_TIPOS_EXAME[] =
 | |
| 		new String[]{ "TOTAL DE EXAMES DE ADMISS\u00C3O",
 | |
| 						"TOTAL DE EXAMES PERI\u00D3DICOS",
 | |
| 						"TOTAL DE EXAMES OCASIONAIS" };
 | |
| 		
 | |
| 	public static final String PAR_ANO = "PAR_ANO";
 | |
| 	public static final String PAR_EMPRESA = "PAR_EMPRESA";
 | |
| 	public static final String PAR_ESTABELECIMENTO = "PAR_ESTABELECIMENTO";
 | |
| 	public static final String PAR_TIPO_EXAME = "PAR_TIPO_EXAME";
 | |
| 	public static final String PAR_RESULTADO = "PAR_RESULTADO";
 | |
| 	public static final String PAR_SEXO = "PAR_SEXO";
 | |
| 	public static final String PAR_GRUPO_ETARIO = "PAR_GRUPO_ETARIO";
 | |
| 	
 | |
| 	/** Creates a new instance of EstatisticasProvider */
 | |
| 	public PesquisasProvider() throws Exception
 | |
| 	{
 | |
| 		DBManager dbm = ( DBManager ) Singleton.getInstance( Singleton.DEFAULT_DBMANAGER /*SingletonConstants.DBMANAGER*/ );
 | |
| 		executer = dbm.getSharedExecuter( this );
 | |
| 	}
 | |
| 	
 | |
| 	public static MetaProvider getProvider()
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		synchronized( LOCK )
 | |
| 		{
 | |
| 			if( instance == null )
 | |
| 			{
 | |
| 				instance = new PesquisasProvider();
 | |
| 			}
 | |
| 		}
 | |
| 		return instance;
 | |
| 	}
 | |
| 	
 | |
| 	public IDObject[] getAllEmpresas()
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		Select select = new Select( new String[]{ "empresas" },
 | |
| 							new String[]{ EmpresaData.ID, EmpresaData.DESIGNACAO_SOCIAL, EmpresaData.DESIGNACAO_SOCIAL_PLAIN },
 | |
| 							new Field( EmpresaData.INACTIVO ).isDifferent( "y" ),
 | |
| 							new String[]{ EmpresaData.DESIGNACAO_SOCIAL_PLAIN }, null );
 | |
| //		Select select = new Select( "SELECT e.id, e.designacao_social FROM empresas e ORDER BY lower( e.designacao_social );" );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		IDObject empresas[] = new IDObject[ array.columnLength() ];
 | |
| 		for( int n = 0; n < empresas.length; n++ )
 | |
| 		{
 | |
| 			empresas[ n ] = new MappableObject( (Integer)array.get( n, 0 ), array.get( n, 1 ) );
 | |
| 		}
 | |
| 		return empresas;
 | |
| 	}
 | |
| 	
 | |
| 	public IDObject []getAllEstabelecimentosForEmpresa( Integer empresaID )
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		return ( ( siprp.FichaDataProvider )siprp.FichaDataProvider.getProvider() ).getAllEstabelecimentosForEmpresa( empresaID );
 | |
| 	}
 | |
| 	
 | |
| 	public int[] countTrabalhadoresEstabelecimentoDezembro( Integer estabelecimentoID, int ano ) 
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		Calendar cal = Calendar.getInstance();
 | |
| 		cal.set( Calendar.YEAR, ano );
 | |
| 		cal.set( Calendar.MONTH, 11 );
 | |
| 		cal.set( Calendar.DAY_OF_MONTH, 30 );
 | |
| 		Select select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "m" ) ).and(
 | |
| 						new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( cal.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		int contagem[] = new int[ 2 ];
 | |
| 		contagem[ 0 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "f" ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( cal.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 1 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		return contagem;
 | |
| 	}
 | |
| 	
 | |
| 	public int[][] countTrabalhadoresEstabelecimentoDezembroPorGrupoEtario( Integer estabelecimentoID, int ano ) 
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		Calendar eoy = Calendar.getInstance();
 | |
| 		eoy.set( Calendar.YEAR, ano );
 | |
| 		eoy.set( Calendar.MONTH, 11 );
 | |
| 		eoy.set( Calendar.DAY_OF_MONTH, 30 );
 | |
| 		
 | |
| 		Calendar today = Calendar.getInstance();
 | |
| 		today.set( Calendar.YEAR, ano );
 | |
| 		today.set( Calendar.MONTH, 11 );
 | |
| 		today.set( Calendar.DAY_OF_MONTH, 31 );
 | |
| 		today.set( Calendar.HOUR_OF_DAY, 23 );
 | |
| 		Calendar age18 = (Calendar) today.clone();
 | |
| 		age18.add( Calendar.YEAR, -18 );
 | |
| 		Calendar age50 = (Calendar) today.clone();
 | |
| 		age50.add( Calendar.YEAR, -50 );
 | |
| 		//0-18
 | |
| 		Select select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "m" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( age18.getTime() ) ).and(
 | |
| 						new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO  ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		int contagem[][] = new int[ 3 ][ 2 ];
 | |
| 		contagem[ 0 ][ 0 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "f" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( age18.getTime() ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO  ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 0 ][ 1 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		//18-49
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "m" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( age18.getTime() ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( age50.getTime() ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 1 ][ 0 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "f" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( age18.getTime() ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( age50.getTime() ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 1 ][ 1 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		
 | |
| 		//50-
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "m" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( age50.getTime() ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 2 ][ 0 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "trabalhadores" },
 | |
| 						new String[]{ "COUNT(" + TrabalhadorData.ID + ")" },
 | |
| 						new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 								new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ).and(
 | |
| 						new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 						new Field( TrabalhadorData.SEXO ).isEqual( "f" ) ).and(
 | |
| 						new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( age50.getTime() ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ).and(
 | |
| 						new Par( new Field( TrabalhadorData.DATA_DEMISSAO ).isGreater( eoy.getTime() ).or(
 | |
| 								new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagem[ 2 ][ 1 ] = ( ( Number ) array.get( 0, 0 ) ).intValue();
 | |
| 		
 | |
| 		return contagem;
 | |
| 	}
 | |
| 	
 | |
| 	public int[][] countExamesEstabelecimentoDezembroPorGrupoEtario( Integer estabelecimentoID, int ano ) 
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		Calendar today = Calendar.getInstance();
 | |
| 		today.set( Calendar.YEAR, ano );
 | |
| 		today.set( Calendar.MONTH, 11 );
 | |
| 		today.set( Calendar.DAY_OF_MONTH, 31 );
 | |
| 		today.set( Calendar.HOUR_OF_DAY, 23 );
 | |
| 		Calendar age18 = (Calendar) today.clone();
 | |
| 		age18.add( Calendar.YEAR, -18 );
 | |
| 		Calendar age50 = (Calendar) today.clone();
 | |
| 		age50.add( Calendar.YEAR, -50 );
 | |
| 		Calendar dates[] = new Calendar[]{ null, age18, age50, null };
 | |
| 		String sexos[] = new String[]{ "m", "f" };
 | |
| 		
 | |
| 		int contagem[][] = new int[ 4 ][ 6 ];
 | |
| 		for( int t = 0; t < TIPOS_EXAME.length; t++ )
 | |
| 		{
 | |
| 			for( int s = 0; s < sexos.length; s++ )
 | |
| 			{
 | |
| 				for( int d = 0; d < dates.length - 1; d++ )
 | |
| 				{
 | |
| 					Select select = 
 | |
| 						new Select( new String[]{ "exames", "trabalhadores" },
 | |
| 							new String[]{ "DISTINCT trabalhadores.id, exames.data" },
 | |
| 							new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ).and(
 | |
| 							new Field( "exames.trabalhador_id" ).isEqual( new Field( "trabalhadores.id" ) ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[s] ) ).and(
 | |
| 							new Field( "YEAR( exames.data )" ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							dates[ d ] == null ? new Field( "exames.id" ).isDifferent( null ) :
 | |
| 													new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( dates[ d ].getTime() ) ).and( 
 | |
| 							dates[ d + 1 ] == null ? new Field( "exames.id" ).isDifferent( null ) :
 | |
| 													new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( dates[ d + 1 ].getTime() ) ).and(
 | |
| 							new Field( "exames.tipo" ).isEqual( new Integer( TIPOS_EXAME[ t ] ) ) ).and(
 | |
| 							new Field( "exames.inactivo" ).isDifferent( "y" ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isDifferent( "y" ) ) );
 | |
| 					try
 | |
| 					{
 | |
| 						Virtual2DArray array = executer.executeQuery( select );
 | |
| 						contagem[ t ][ s * 3 + d ] = array.columnLength();
 | |
| //System.out.println( select + ": " + contagem[ t ][ s * 3 + d ] );
 | |
| 					}
 | |
| 					catch( Exception ex )
 | |
| 					{
 | |
| 						contagem[ t ][ s * 3 + d ] = -1;
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		return contagem;
 | |
| 	}
 | |
| 	
 | |
| 	public int[][] countExamesOcasionaisEstabelecimentoDezembroPorGrupoEtario( Integer estabelecimentoID, int ano ) 
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		Calendar today = Calendar.getInstance();
 | |
| 		today.set( Calendar.YEAR, ano );
 | |
| 		today.set( Calendar.MONTH, 11 );
 | |
| 		today.set( Calendar.DAY_OF_MONTH, 31 );
 | |
| 		today.set( Calendar.HOUR_OF_DAY, 23 );
 | |
| 		Calendar age18 = (Calendar) today.clone();
 | |
| 		age18.add( Calendar.YEAR, -18 );
 | |
| 		Calendar age50 = (Calendar) today.clone();
 | |
| 		age50.add( Calendar.YEAR, -50 );
 | |
| 		Calendar dates[] = new Calendar[]{ null, age18, age50, null };
 | |
| 		String sexos[] = new String[]{ "m", "f" };
 | |
| 		
 | |
| 		int contagem[][] = new int[ TIPOS_OCASIONAL.length ][ ( dates.length - 1 ) * sexos.length ];
 | |
| 		for( int t = 0; t < TIPOS_OCASIONAL.length; t++ )
 | |
| 		{
 | |
| 			for( int s = 0; s < sexos.length; s++ )
 | |
| 			{
 | |
| 				for( int d = 0; d < dates.length - 1; d++ )
 | |
| 				{
 | |
| 					if( TIPOS_OCASIONAL[t] == -1 )
 | |
| 					{
 | |
| 						contagem[ t ][ s * 3 + d ] = -1;
 | |
| 						continue;
 | |
| 					}
 | |
| 						
 | |
| 					Select select = 
 | |
| 						new Select( new String[]{ "exames", "trabalhadores" },
 | |
| 							new String[]{ "DISTINCT trabalhadores.id, exames.data" },
 | |
| 							new Field( "estabelecimento_id" ).isEqual( estabelecimentoID ).and(
 | |
| 							new Field( "exames.trabalhador_id" ).isEqual( new Field( "trabalhadores.id" ) ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[s] ) ).and(
 | |
| 							new Field( "YEAR( exames.data )" ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							dates[ d ] == null ? new Field( "exames.id" ).isDifferent( null ) :
 | |
| 													new Field( TrabalhadorData.DATA_NASCIMENTO ).isLessOrEqual( dates[ d ].getTime() ) ).and( 
 | |
| 							dates[ d + 1 ] == null ? new Field( "exames.id" ).isDifferent( null ) :
 | |
| 													new Field( TrabalhadorData.DATA_NASCIMENTO ).isGreater( dates[ d + 1 ].getTime() ) ).and(
 | |
| 							new Field( "exames.tipo" ).isEqual( new Integer( 3 ) ) ).and(
 | |
| 							new Field( "exames.ocasional" ).isEqual( new Integer( TIPOS_OCASIONAL[ t ] ) ) ).and(
 | |
| 							new Field( "exames.inactivo" ).isDifferent( "y" ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isDifferent( "y" ) ) );
 | |
| 					try
 | |
| 					{
 | |
| 						Virtual2DArray array = executer.executeQuery( select );
 | |
| 						contagem[ t ][ s * 3 + d ] = array.columnLength();
 | |
| 					}
 | |
| 					catch( Exception ex )
 | |
| 					{
 | |
| 						contagem[ t ][ s * 3 + d ] = -1;
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		return contagem;
 | |
| 	}
 | |
| 	
 | |
| 	public double[] countNumeroMedioTrabalhadoresEmpresa( Integer empresaID, int ano )
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		double contagens[] = new double[ 2 ];;
 | |
| 		Select select;
 | |
| 		String sexos[] = new String[]{ "m", "f" };
 | |
| 
 | |
| 		for( int n = 0; n < sexos.length; n++ )
 | |
| 		{
 | |
| 			select = 
 | |
| 				new Select( new String[]{ "estabelecimentos", "trabalhadores" },
 | |
| 							new String[]{ "COUNT(trabalhadores.id)" },
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ).and( 
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLess( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_DEMISSAO + ")"  ).isGreater( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[ n ] ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ) );
 | |
| 			Virtual2DArray array = executer.executeQuery( select );
 | |
| 			contagens[ n ] = ( ( Number ) array.get( 0, 0 ) ).doubleValue();
 | |
| 		}
 | |
| 		for( int n = 0; n < sexos.length; n++ )
 | |
| 		{
 | |
| 			select = 
 | |
| 				new Select( new String[]{ "estabelecimentos", "trabalhadores" },
 | |
| 							new String[]{ "SUM( MONTH( data_demissao ) )" },
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ).and( 
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLess( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Field( "YEAR(" + TrabalhadorData.DATA_DEMISSAO + ")"  ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[ n ] ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) )  );
 | |
| System.out.println( "SELECT: " + select );
 | |
| 			Virtual2DArray array = executer.executeQuery( select );
 | |
| 			if( array.get( 0, 0 ) != null )
 | |
| 			{
 | |
| 				contagens[ n ] += ( ( Number ) array.get( 0, 0 ) ).doubleValue() / 12.0;
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		for( int n = 0; n < sexos.length; n++ )
 | |
| 		{
 | |
| 			select = 
 | |
| 				new Select( new String[]{ "estabelecimentos", "trabalhadores" },
 | |
| 							new String[]{ "SUM( ( 1 + 12 - MONTH( data_admissao ) ) )" },
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ).and( 
 | |
| 							new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_DEMISSAO + ")"  ).isGreater( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[ n ] ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ) );
 | |
| 			Virtual2DArray array = executer.executeQuery( select );
 | |
| 			if( array.get( 0, 0 ) != null )
 | |
| 			{
 | |
| 				contagens[ n ] += ( ( Number ) array.get( 0, 0 ) ).doubleValue() / 12.0;
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		for( int n = 0; n < sexos.length; n++ )
 | |
| 		{
 | |
| 			select = 
 | |
| 				new Select( new String[]{ "estabelecimentos", "trabalhadores" },
 | |
| 							new String[]{ "SUM( ( 1 + MONTH( data_demissao ) - MONTH( data_admissao ) ) )" },
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ).and( 
 | |
| 							new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							new Field( "YEAR(" + TrabalhadorData.DATA_DEMISSAO + ")"  ).isEqual( new Integer( ano ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[ n ] ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ) );
 | |
| 			Virtual2DArray array = executer.executeQuery( select );
 | |
| 			if( array.get( 0, 0 ) != null )
 | |
| 			{
 | |
| 				contagens[ n ] += ( ( Number ) array.get( 0, 0 ) ).doubleValue() / 12.0;
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		return contagens;
 | |
| 	}
 | |
| 	
 | |
| 	public double[] countNumeroTotalTrabalhadoresEmpresa( Integer empresaID, int ano )
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		double contagens[] = new double[ 2 ];;
 | |
| 		Select select;
 | |
| 		String sexos[] = new String[]{ "m", "f" };
 | |
| 
 | |
| 		for( int n = 0; n < sexos.length; n++ )
 | |
| 		{
 | |
| 			select = 
 | |
| 				new Select( new String[]{ "estabelecimentos", "trabalhadores" },
 | |
| 							new String[]{ "COUNT(trabalhadores.id)" },
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ).and( 
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_ADMISSAO + ")"  ).isLessOrEqual( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_ADMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Par( new Field( "YEAR(" + TrabalhadorData.DATA_DEMISSAO + ")"  ).isGreaterOrEqual( new Integer( ano ) ).or(
 | |
| 									new Field( TrabalhadorData.DATA_DEMISSAO ).isEqual( null ) ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( TrabalhadorData.SEXO ).isEqual( sexos[ n ] ) ).and(
 | |
| 							new Field( "trabalhadores.inactivo" ).isEqual( "n" ) ) );
 | |
| 			Virtual2DArray array = executer.executeQuery( select );
 | |
| 			contagens[ n ] = ( ( Number ) array.get( 0, 0 ) ).doubleValue();
 | |
| 		}
 | |
| 		return contagens;
 | |
| 	}
 | |
| 	
 | |
| 	public String []getNomesExames()
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		String nomes[];
 | |
| 		Select select = 
 | |
| 			new Select( new String[]{ "tipos_exames_comp" },
 | |
| 						new String[]{ "descricao", "ordem" },
 | |
| 						null,
 | |
| 						new String[]{ "ordem" }, null );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		nomes = new String[ array.columnLength() ];
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			nomes[ n ] = ( String )array.get( n, 0 );
 | |
| 		}
 | |
| 		return nomes;
 | |
| 	}
 | |
| 	
 | |
| 	public int []countExamesComplementaresEmpresa( Integer empresaID, int ano )
 | |
| 		throws Exception
 | |
| 	{
 | |
| //		Vector perfis[] = new Vector[ 2 ];
 | |
| //		Hashtable contagens[] = new Hashtable[ 2 ];
 | |
| //		Select select;
 | |
| //		Virtual2DArray array;
 | |
| //		
 | |
| //		for( int p = 0; p < 2; p++ )
 | |
| //		{
 | |
| //			Integer pAux = new Integer( p + 1 );
 | |
| //			perfis[ p ] = new Vector();
 | |
| //			select = new Select( new String[]{"estabelecimentos", "trabalhadores", "marcacoes_trabalhador"},
 | |
| //							new String[]{"COUNT(marcacoes_trabalhador.id)", TrabalhadorData.PERFIL },
 | |
| //							new Field( "marcacoes_trabalhador.trabalhador_id" ).isEqual( new Field( "trabalhadores.id" ) ).and(
 | |
| //							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ) ).and(
 | |
| //							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| //							new Field( MarcacaoTrabalhadorData.TIPO ).isEqual( new Integer( MarcacaoTrabalhadorData.TIPO_EXAMES ) ) ).and(
 | |
| //							new Field( "YEAR( marcacoes_trabalhador.data ) " ).isEqual( new Integer( ano ) ).and( 
 | |
| //							new Field( MarcacaoTrabalhadorData.ESTADO ).in( new Integer[]{ new Integer( 1 ), new Integer( 2 ) } ) ) ).and(
 | |
| //							new Field( "trabalhadores.perfil" ).isEqual( pAux ) ) );
 | |
| //			array = executer.executeQuery( select );
 | |
| //
 | |
| //			select = 
 | |
| //				new Select( new String[]{ "prt_elementos_protocolo", "prt_tipos_elementos_protocolo" },
 | |
| //							new String[]{ "DISTINCT prt_tipos_elementos_protocolo.grupo_protocolo_id" },
 | |
| //							new Field( "prt_elementos_protocolo.empresa_id" ).isEqual( empresaID ).and(
 | |
| //							new Field( "prt_elementos_protocolo.tipo_elemento_protocolo_id" ).isEqual( new Field( "prt_elementos_protocolo.id" ) ) ).and(
 | |
| //							new Field( "pr_elementos_protocolo.perfil" ).isEqual( new Integer( p + 1 ) ) ) );
 | |
| //			array = executer.executeQuery( select );
 | |
| //			for( int ecd = 0; ecd < array.columnLength(); ecd++ )
 | |
| //			{
 | |
| //				perfis[ p ].add( ( Integer ) array.get( 0, 0 ) );
 | |
| //			}
 | |
| //		}
 | |
| //		
 | |
| //		
 | |
| //		return contagens;
 | |
| 		
 | |
| 		
 | |
| 		int contagens[];
 | |
| 		Select select;
 | |
| 		select = new Select( new String[]{"empresas"}, new String[]{ "perfil_1", "perfil_2" },
 | |
| 								new Field( "id" ).isEqual( empresaID ) );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		String p1Str = (String)array.get( 0, 0 );
 | |
| 		String p2Str = (String)array.get( 0, 1 );
 | |
| 		Number perfil1 = ( p1Str != null && p1Str.length() > 0 )?new Integer( p1Str ):null;
 | |
| 		Number perfil2 = ( p2Str != null && p2Str.length() > 0 )?new Integer( p2Str ):null;
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "tipos_exames_comp" },
 | |
| 						new String[]{ "id", "ordem" },
 | |
| 						null,
 | |
| 						new String[]{ "ordem" }, null );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagens = new int[ array.columnLength() ];
 | |
| 		Hashtable idExames = new Hashtable();
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			idExames.put( ( Number )array.get( n, 0 ), new Integer( n ) );
 | |
| 		}
 | |
| 		if( perfil1 == null && perfil2 == null )
 | |
| 		{
 | |
| 			return contagens;
 | |
| 		}
 | |
| 		else if( perfil1 == null )
 | |
| 		{
 | |
| 			perfil1 = perfil2;
 | |
| 		}
 | |
| 		else if( perfil2 == null )
 | |
| 		{
 | |
| 			perfil2 = perfil1;
 | |
| 		}
 | |
| 		select = new Select( new String[]{"estabelecimentos", "trabalhadores", "marcacoes_trabalhador"},
 | |
| 							new String[]{"COUNT(marcacoes_trabalhador.id)", TrabalhadorData.PERFIL },
 | |
| 							new Field( "marcacoes_trabalhador.trabalhador_id" ).isEqual( new Field( "trabalhadores.id" ) ).and(
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( new Field( "estabelecimentos.id" ) ) ).and(
 | |
| 							new Field( "empresa_id" ).isEqual( empresaID ) ).and(
 | |
| 							new Field( MarcacaoTrabalhadorData.TIPO ).isEqual( new Integer( MarcacaoTrabalhadorData.TIPO_EXAMES ) ) ).and(
 | |
| 							new Field( "YEAR( marcacoes_trabalhador.data ) " ).isEqual( new Integer( ano ) ).and( 
 | |
| 							new Field( Marcacao.REALIZADA ).isEqual( "y" ) ) ),
 | |
| 							new String[]{ TrabalhadorData.PERFIL },
 | |
| 							new String[]{ TrabalhadorData.PERFIL } );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		int numeroExames[] = new int[ 2 ];
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Integer perfil = (Integer)array.get( n, 1 );
 | |
| 			if( perfil == null || perfil.intValue() == 1 )
 | |
| 			{
 | |
| 				numeroExames[0] += ( (Number) array.get( n, 0 ) ).intValue();
 | |
| 			}
 | |
| 			else if( perfil.intValue() == 2 )
 | |
| 			{
 | |
| 				numeroExames[1] += ( (Number) array.get( n, 0 ) ).intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		Hashtable hash = new Hashtable();
 | |
| 		select = new Select( new String[]{ "exames_perfis" },
 | |
| 								new String[]{ "tipo", "multiplicador" },
 | |
| 								new Field( "perfil" ).isEqual( perfil1 ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Number tipo = (Number) array.get( n, 0 );
 | |
| 			if( tipo == null )
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 			Number multiplicador = (Number) array.get( n, 1 );
 | |
| 			if( multiplicador == null )
 | |
| 			{
 | |
| 				multiplicador = new Integer( 1 );
 | |
| 			}
 | |
| 			if( idExames.containsKey( tipo ) )
 | |
| 			{
 | |
| 				int pos = ((Integer)idExames.get( tipo )).intValue();
 | |
| 				contagens[ pos ] += numeroExames[0] * multiplicador.intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		select = new Select( new String[]{ "exames_perfis" },
 | |
| 								new String[]{ "tipo", "multiplicador" },
 | |
| 								new Field( "perfil" ).isEqual( perfil2 ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Number tipo = (Number) array.get( n, 0 );
 | |
| 			if( tipo == null )
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 			Number multiplicador = (Number) array.get( n, 1 );
 | |
| 			if( multiplicador == null )
 | |
| 			{
 | |
| 				multiplicador = new Integer( 1 );
 | |
| 			}
 | |
| 			if( idExames.containsKey( tipo ) )
 | |
| 			{
 | |
| 				int pos = ((Integer)idExames.get( tipo )).intValue();
 | |
| 				contagens[ pos ] += numeroExames[1] * multiplicador.intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		return contagens;
 | |
| 	}
 | |
| 	
 | |
| 	public int []countExamesComplementaresEstabelecimento( Integer estabelecimentoID, int ano )
 | |
| 		throws Exception
 | |
| 	{
 | |
| 		int contagens[];
 | |
| 		Select select;
 | |
| 		select = new Select( new String[]{"estabelecimentos", "empresas"}, 
 | |
| 								new String[]{ "empresas.perfil_1", "empresas.perfil_2" },
 | |
| 								new Field( "estabelecimentos.id" ).isEqual( estabelecimentoID ).and(
 | |
| 								new Field( "estabelecimentos.empresa_id" ).isEqual( new Field( "empresas.id" ) ) ) );
 | |
| 		Virtual2DArray array = executer.executeQuery( select );
 | |
| 		String p1Str = (String)array.get( 0, 0 );
 | |
| 		String p2Str = (String)array.get( 0, 1 );
 | |
| 		Number perfil1 = ( p1Str != null && p1Str.length() > 0 )?new Integer( p1Str ):null;
 | |
| 		Number perfil2 = ( p2Str != null && p2Str.length() > 0 )?new Integer( p2Str ):null;
 | |
| 		select = 
 | |
| 			new Select( new String[]{ "tipos_exames_comp" },
 | |
| 						new String[]{ "id", "ordem" },
 | |
| 						null,
 | |
| 						new String[]{ "ordem" }, null );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		contagens = new int[ array.columnLength() ];
 | |
| 		Hashtable idExames = new Hashtable();
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			idExames.put( ( Number )array.get( n, 0 ), new Integer( n ) );
 | |
| 		}
 | |
| 		if( perfil1 == null && perfil2 == null )
 | |
| 		{
 | |
| 			return contagens;
 | |
| 		}
 | |
| 		else if( perfil1 == null )
 | |
| 		{
 | |
| 			perfil1 = perfil2;
 | |
| 		}
 | |
| 		else if( perfil2 == null )
 | |
| 		{
 | |
| 			perfil2 = perfil1;
 | |
| 		}
 | |
| 		select = new Select( new String[]{"trabalhadores", "marcacoes_trabalhador"},
 | |
| 							new String[]{"COUNT(marcacoes_trabalhador.id)", TrabalhadorData.PERFIL },
 | |
| 							new Field( "marcacoes_trabalhador.trabalhador_id" ).isEqual( new Field( "trabalhadores.id" ) ).and(
 | |
| 							new Field( "trabalhadores.estabelecimento_id" ).isEqual( estabelecimentoID ) ).and(
 | |
| 							new Field( MarcacaoTrabalhadorData.TIPO ).isEqual( new Integer( MarcacaoTrabalhadorData.TIPO_EXAMES ) ) ).and(
 | |
| 							new Field( "YEAR( marcacoes_trabalhador.data ) " ).isEqual( new Integer( ano ) ).and( 
 | |
| 							new Field( Marcacao.REALIZADA ).isEqual( "y" ) ) ),
 | |
| 							new String[]{ TrabalhadorData.PERFIL },
 | |
| 							new String[]{ TrabalhadorData.PERFIL } );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		int numeroExames[] = new int[ 2 ];
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Integer perfil = (Integer)array.get( n, 1 );
 | |
| 			if( perfil == null || perfil.intValue() == 1 )
 | |
| 			{
 | |
| 				numeroExames[0] += ( (Number) array.get( n, 0 ) ).intValue();
 | |
| 			}
 | |
| 			else if( perfil.intValue() == 2 )
 | |
| 			{
 | |
| 				numeroExames[1] += ( (Number) array.get( n, 0 ) ).intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		Hashtable hash = new Hashtable();
 | |
| 		select = new Select( new String[]{ "exames_perfis" },
 | |
| 								new String[]{ "tipo", "multiplicador" },
 | |
| 								new Field( "perfil" ).isEqual( perfil1 ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Number tipo = (Number) array.get( n, 0 );
 | |
| 			if( tipo == null )
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 			Number multiplicador = (Number) array.get( n, 1 );
 | |
| 			if( multiplicador == null )
 | |
| 			{
 | |
| 				multiplicador = new Integer( 1 );
 | |
| 			}
 | |
| 			if( idExames.containsKey( tipo ) )
 | |
| 			{
 | |
| 				int pos = ((Integer)idExames.get( tipo )).intValue();
 | |
| 				contagens[ pos ] += numeroExames[0] * multiplicador.intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		select = new Select( new String[]{ "exames_perfis" },
 | |
| 								new String[]{ "tipo", "multiplicador" },
 | |
| 								new Field( "perfil" ).isEqual( perfil2 ) );
 | |
| 		array = executer.executeQuery( select );
 | |
| 		for( int n = 0; n < array.columnLength(); n++ )
 | |
| 		{
 | |
| 			Number tipo = (Number) array.get( n, 0 );
 | |
| 			if( tipo == null )
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 			Number multiplicador = (Number) array.get( n, 1 );
 | |
| 			if( multiplicador == null )
 | |
| 			{
 | |
| 				multiplicador = new Integer( 1 );
 | |
| 			}
 | |
| 			if( idExames.containsKey( tipo ) )
 | |
| 			{
 | |
| 				int pos = ((Integer)idExames.get( tipo )).intValue();
 | |
| 				contagens[ pos ] += numeroExames[1] * multiplicador.intValue();
 | |
| 			}
 | |
| 		}
 | |
| 		return contagens;
 | |
| 	}
 | |
| }
 |