Эта функция возвращает 4-значное значение года с базовым числовым значением, соответствующим метке времени с первой миллисекундой первого дня года, содержащего значение, указанное в поле date.
period_no — целое число, где 0 обозначает год, включающий значение, указанное в поле date. Отрицательные значения, заданные в поле period_no, означают предшествующие годы, положительные — последующие.
first_month_of_year
Если необходимо работать с годами (финансовыми), которые начинаются не в январе, задайте значение от 2 до 12 в поле first_month_of_year. Отображаемое значение будет строчным, показывающим два года.
В этих примерах используется формат даты DD/MM/YYYY. Формат даты указан в операторе SET DateFormat в верхней части скрипта загрузки данных. Измените формат в примерах согласно своим пожеланиям.
Примеры скриптов
Пример
Результат
yearname ( '19/10/2001')
Возвращает 2001.
yearname ( '19/10/2001', -1 )
Возвращает 2000.
yearname ( '19/10/2001', 0, 4)
Возвращает 2001-2002.
Example:
Добавьте образец скрипта в свое приложение и запустите. Затем добавьте на лист приложения поля, указанные в столбце с результатами, чтобы увидеть результаты.
В этом примере выполняется обнаружение первого дня в году каждой даты счета в таблице, где первый месяц в году указан как месяц 4.
В этом примере создается цифровое имя четыре-плюс-четыре для годов, в которых обнаруживается каждая дата счета в таблице. Это является следствием того, что первый месяц в году указан как месяц 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;
Результирующая таблица содержит исходные даты и столбец с возвращенным значением функции 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
Помогла ли вам эта страница?
Если вы обнаружили какую-либо проблему на этой странице и с ее содержанием — будь то опечатка, пропущенный шаг или техническая ошибка, сообщите нам об этом, чтобы мы смогли ее исправить!