yearname – função de script e gráfico
Essa função retorna um ano com quatro dígitos como valor de exibição com um valor numérico subjacente que corresponde a um carimbo de data/hora com o primeiro milissegundo do primeiro dia do ano que contém date.
Sintaxe:
YearName(date[, period_no[, first_month_of_year]] )
Tipo de dados de retorno: dual
Argumentos:
Argumento | Descrição |
---|---|
date | A data para avaliar. |
period_no | period_no é um inteiro, em que o valor 0 indica o ano que contém a date. Valores negativos em period_no indicam anos precedentes e valores positivos indicam anos 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. O valor de exibição serão caracteres que mostram dois anos. |
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:
yearname ( '19/10/2001')
Retorna 2001.
Exemplo 2:
yearname ( '19/10/2001', -1 )
Retorna '2000.
Exemplo 3:
yearname ( '19/10/2001', 0, 4)
Retorna '2001-2002.
Exemplo 4:
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 cria um nome de quatro dígitos mais quatro para os anos, em que encontra-se cada data da fatura na tabela. Isso ocorre porque o primeiro mês no ano está especificado como mês 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 *,
YearName(InvDate, 0, 4) AS YrName
Resident TempTable;
Drop table TempTable;
A tabela resultante contém as datas originais e uma coluna com o valor de retorno da função yearname().
InvDate | YrName |
---|---|
28/03/2012 | 2011-2012 |
10/12/2012 | 2012-2013 |
5/2/2013 | 2012-2013 |
31/3/2013 | 2012-2013 |
19/5/2013 | 2013-2014 |
15/9/2013 | 2013-2014 |
11/12/2013 | 2013-2014 |
2/3/2014 | 2013-2014 |
14/5/2014 | 2014-2015 |
13/6/2014 | 2014-2015 |
7/7/2014 | 2014-2015 |
4/8/2014 | 2014-2015 |