inmonths – função de script e gráfico
Essa função verifica se um carimbo de data/hora está no mesmo mês, bimestre, trimestre, período de quatro meses ou meio ano da data base. Também é possível descobrir se uma data/hora está dentro de um período de tempo anterior ou seguinte.
Sintaxe:
InMonths(n_months, timestamp, base_date, period_no [, first_month_of_year])
Tipo de dados de retorno: Booleano
Argumentos:
Argumento | Descrição |
---|---|
n_months |
O número de meses que define o período. Um inteiro ou uma expressão que é resolvida como um inteiro, que deve ser um dos seguintes: 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. |
Exemplos e resultados:
Esses 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 carregamento. Altere o formato nos exemplos para atender às suas necessidades.
Exemplo 1:
inmonths(4, '25/01/2013', '25/04/2013', 0)
Retorna 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.
Exemplo 2:
inmonths(4, '25/05/2013', '25/04/2013', 0)
Retorna False. Porque 25/05/2013 está fora do mesmo período que o exemplo anterior.
Exemplo 3:
inmonths(4, '25/11/2012', '01/02/2013', -1 )
Retorna 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.
Exemplo 4:
inmonths( 4, '25/05/2006', '01/03/2006', 0, 3)
Retorna 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.
Exemplo 5:
Adicione o script de exemplo ao seu documento e execute-o. Em seguida, adicione pelo menos os campos listados na coluna de resultados a um documento 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).
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) |