inmonthstodate – função de script e gráfico
Esta função descobre se um carimbo de data/hora se enquadra na parte de um período do mês, bimestre, trimestre, período de quatro meses ou semestre até e incluindo o último milissegundo de base_date. 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:
inmonthstodate(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é o final de 25/04/2013, em que fica o valor de base_date, 25/04/2013.
Exemplo 2:
inmonthstodate(4, '26/04/2013', '25/04/2006', 0)
Retorna False. Porque 26/04/2013 está fora do mesmo período que o exemplo anterior.
Exemplo 3:
inmonthstodate(4, '25/09/2005', '01/02/2006', -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/2005 para 01/02/2006.
Exemplo 4:
inmonthstodate(4, '25/04/2006', '01/06/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é 01/06/2006 em vez de 01/05/2006 até 01/06/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 até e incluindo a base_date deslocada para a frente por quatro períodos de dois meses (especificando o period_no como 4).
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 *,
InMonthsToDate(2, InvDate, '15/02/2013', 4) AS InMths2DPlus4
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 pesquisa é de 01/09/2013 até 15/10/2013, porque o valor debase_date é deslocado 8 meses para a frente, a partir do valor na função (15/02/2013).
InvDate | InMths2DPlus4 |
---|---|
28/03/2012 | 0 (False) |
10/12/2012 | 0 (False) |
5/2/2013 | 0 (False) |
31/3/2013 | 0 (False) |
19/5/2013 | 0 (False) |
15/9/2013 | -1 (True) |
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) |