Esta função descobre se um timestamp cai dentro do mesmo mês, bi-mês, trimestre, terço ou metade do ano como uma data base. Também é possível descobrir se o timestamp cai dentro de um período de tempo anterior ou seguinte.
O número de meses que define o período. Um número inteiro ou uma expressão que resulta em um número inteiro que será: 1 (equivalente à função inmonth()), 2 (bimestre), 3 (equivalente à função inquarter()), 4 (quadrimestre) ou 6 (semestre).
timestamp
A data que você deseja comparar com base_date.
base_date
Data que é usada para avaliar o período.
period_no
O período pode ser deslocado por period_no, um inteiro ou expressão que resolve um inteiro, no qual o valor 0 indica o período que contém base_date. Valores negativos em period_no indicam períodos precedentes e valores positivos indicam períodos sucessivos.
first_month_of_year
Se desejar trabalhar com anos (fiscais) que não comecem em janeiro, indique um valor entre 2 e 12 em first_month_of_year.
Estes exemplos usam o formato de data DD/MM/YYYY. O formato de data é especificado no comando SET DateFormat na parte superior do seu script de carga de dados. Altere o formato nos exemplos para atender às suas necessidades.
Exemplos de scripts
Exemplo
Resultado
inmonths(4, '25/01/2013', '25/04/2013', 0)
Returna True. Como o valor de timestamp, 25/01/2013, fica dentro do período de quatro meses 01/01/2013 até 30/04/2013, em que fica o valor de base_date, 25/04/2013.
inmonths(4, '25/05/2013', '25/04/2013', 0)
Returna False. Porque 25/05/2013 está fora do mesmo período que o exemplo anterior.
inmonths(4, '25/11/2012', '01/02/2013', -1 )
Returna True. Como o valor de period_no, -1, muda o período de busca de volta para um período de quatro meses (o valor de n-months), que deixa o período de busca de 01/09/2012 para 31/12/2012.
inmonths( 4, '25/05/2006', '01/03/2006', 0, 3)
Returna True. Como o valor de first_month_of_year é definido para 3, o que torna o período de busca 01/03/2006 até 30/07/2006 em vez de 01/01/2006 até 30/04/2006.
Example:
Adicione o script de exemplo ao seu aplicativo e execute-o. Em seguida, adicione os campos listados na coluna de resultados a uma pasta para ver o resultado.
Este exemplo verifica se a data da fatura na tabela cai na parte do período de dois meses que inclui base_date deslocada para a frente por um período de dois meses (especificando o period_no como 1).
TempTable:
LOAD RecNo() as InvID, * Inline [
InvDate
28/03/2012
10/12/2012
5/2/2013
31/3/2013
19/5/2013
15/9/2013
11/12/2013
2/3/2014
14/5/2014
13/6/2014
7/7/2014
4/8/2014
];
InvoiceData:
LOAD *,
InMonths(2, InvDate, '11/02/2013', 1) AS InMthsPlus1
Resident TempTable;
Drop table TempTable;
A tabela resultante contém as datas originais e uma coluna com o valor de retorno da função InMonths().
O período de busca é 01/03/2013 até 30/04/2013, porque o valor debase_date é deslocado dois meses para a frente, a partir do valor na função (11/02/2013).
Tabela de resultados
InvDate
InMthsPlus1
28/03/2012
0 (False)
10/12/2012
0 (False)
5/2/2013
0 (False)
31/3/2013
-1 (True)
19/5/2013
0 (False)
15/9/2013
0 (False)
11/12/2013
0 (False)
2/3/2014
0 (False)
14/5/2014
0 (False)
13/6/2014
0 (False)
7/7/2014
0 (False)
4/8/2014
0 (False)
Esta página ajudou?
Se você encontrar algum problema com esta página ou seu conteúdo - um erro de digitação, uma etapa ausente ou um erro técnico - informe-nos como podemos melhorar!