03.11.2022 Юлия Романяк 54450
Функция 1С РАЗНОСТЬДАТ

Содержание:

1. Как использовать функцию РАЗНОСТЬДАТ?

2. Как использовать функцию ДОБАВИТЬКДАТЕ?  

   

1.      Как использовать функцию РАЗНОСТЬДАТ?


В отличие от встроенного языка 1С, который позволяет производить операции вычитания и сложения дат при помощи математических функций, при написании запросов 1С требуется другой подход. В запросе 1С для того, чтобы определить отрезок времени между двумя датами в запросе 1С, необходимо использовать функцию РАЗНОСТЬДАТ(<Дата1>, <Дата2>, <Тип>).


Дата1 – вычитаемая дата

Дата2 – исходная дата


Тип (периодичность) – тип периода, для которого вычисляется значение функции. Может принимать значения СЕКУНДА, МИНУТА, ЧАС, ДЕНЬ, МЕСЯЦ, ГОД.


Таким образом, если в запросе 1С нужно вычислить сколько дней между двумя датами 01.01.2021 и 15.01.2021 нужно использовать функцию РАЗНОСТЬДАТ следующим образом:

РАЗНОСТЬДАТ(ДАТАВРЕМЯ(2021, 1, 1, 0, 0, 0), ДАТАВРЕМЯ(2021, 1, 15, 0, 0, 0), ДЕНЬ).

Запрос выдаст результат -14 дней.


В примере выше у нас обе даты указаны с временем начала дня (0:00:00).

Попробуем изменить время обеих дат, укажем для вычитаемой даты время 14:00, а исходную дату поместим в конец дня:

РАЗНОСТЬДАТ(ДАТАВРЕМЯ(2021, 1, 1, 14, 0, 0), ДАТАВРЕМЯ(2021, 1, 15, 23, 59, 59), ДЕНЬ)

Результат получим тот же – 14 дней.


Таким образом, нужно помнить, что при вычитании дат рассматриваемая функция отбрасывает все значения после значения для указанной периодичности. В нашем примере – часы, минуты и секунды. Другими словами, при выбранной периодичности ДЕНЬ функция автоматически поместит обе даты в начало дня (если указать периодичность МЕСЯЦ – в начало месяца и т.д.).   


2.      Как использовать функцию ДОБАВИТЬКДАТЕ?


Иногда нужно вычислить разность между двумя датами, определив не количество полных дней, а рассчитав общее количество полных и неполных дней. В этом случае нужно предварительно обработать исходные даты с тем, чтобы привести вычитаемую дату к началу предыдущего периода. Для этого нужно сначала проверить совпадает ли вычитаемая дата с началом дня, и если не совпадает – переместить ее в начало предыдущего периода при помощи функции ДОБАВИТЬКДАТЕ():


ВЫБРАТЬ

            РАЗНОСТЬДАТ(&Дата1, &Дата2, ДЕНЬ) КАК Количество Полных Периодов,

            РАЗНОСТЬДАТ(ВЫБОР

                                    КОГДА НАЧАЛОПЕРИОДА(&Дата1, ДЕНЬ) = &Дата1

                                               ТОГДА &Дата1

                                    ИНАЧЕ ДОБАВИТЬКДАТЕ(&Дата1, ДЕНЬ, -1)

                        КОНЕЦ, &Дата2, ДЕНЬ) КАК Количество Неполных Периодов


Зададим значения &Дата1 - 01.01.2021 14:00:00, &Дата2 - 15.01.2021 0:00:00.

Получим в результате выполнения запроса:

КоличествоПолныхПериодов – 14

КоличествоНеполныхПериодов – 15

 

Теперь зададим в параметре &Дата1 - 01.01.2021 0:00:00

Получим результат:

КоличествоПолныхПериодов – 14

КоличествоНеполныхПериодов – 14


Синтаксис: ДОБАВИТЬКДАТЕ(<Дата>, <Тип>, <Количество>).

Дата – обрабатываемая дата

Тип (периодичность) - тип периода, для которого вычисляется значение функции. Может принимать значения СЕКУНДА, МИНУТА, ЧАС, ДЕНЬ, МЕСЯЦ, ГОД.


Количество – количество периодов, на которые нужно «сдвинуть» дату.


Данную функцию можно использовать как для сложения, так и для вычитания. Для того, чтобы уменьшить дату на нужное количество периодов, указывается отрицательное значение в параметре <Количество>.


Следует также помнить, что система обрабатывает значение параметра <Количество> как целое число, отбрасывая дробную часть. И несмотря на то, что система не выдаст ошибку при задании такой формулы в вычисляемом поле:


ДОБАВИТЬКДАТЕ(&Дата1, ДЕНЬ, 1.5),


Дата1 будет увеличена ровно на один день.


Специалист компании "Кодерлайн"

Юлия Романяк


Наши проекты

ООО «Стейдж Энтертейнмент Россия»
ООО «Стейдж Энтертейнмент Россия»

Отрасль:
Театральная деятельность

Внедренное типовое решение:
Платформа 1С:Предприятие 8

Реализован процесс трансформации данных бухгалтерского учета по РСБУ в дан...

Внедрение ПП "1С:CRM ПРОФ" в ООО «Торговый Дом Факел»
ООО «Торговый Дом Факел»

Отрасль:
Производство

Внедренное типовое решение:
1С:CRM ПРОФ

- Управление отношениями с клиентами (CRM) ...

ООО «Лаборатория успеха»
ООО «Лаборатория успеха»

Отрасль:
Общественное и плановое питание, гостиничный бизнес, туризм

Внедренное типовое решение:
1С:Управление холдингом 8

Бухгалтерский учет;
Расчет зарплаты и кадровый учет;...

ПЭК
ПЭК

Отрасль:
Грузоперевозки

Внедренное типовое решение:
1С:Управление производственным предприятием

- Внедрение функционала управления НСИ;
- Рефакторинг;
- Оптимизация общег...

Внедрение ПП "1С:Управление небольшой фирмой 8 ПРОФ" в ООО «Шокостайл»
ООО «Шокостайл»

Отрасль:
Производство

Внедренное типовое решение:
1С:Управление небольшой фирмой 8 ПРОФ

Управление продажами, логистикой и транспортом (SFM, WMS, TMS):
- Планирование п...

Внедрение системы финансового учета БИТ:Финанс
ООО «Алькор и Ко» (Л’Этуаль)

Отрасль:
Торговля

Внедренное типовое решение:
БИТ.Финанс

- Финансовый учет;
- Поддержка проекта внедрения МСФО;
- Регламентные рабо...

ООО «ЛукБелОйл»
ООО «ЛукБелОйл»

Отрасль:
Нефтегазовая отрасль

Внедренное типовое решение:

- Обследовании бизнес-процессов «Документооборот», «Казначейство и Бюджети...

ООО «ПраксисКом»
ООО «ПраксисКом»

Отрасль:
Аутсорсинг бухгалтерских услуг

Внедренное типовое решение:
1С:Управление небольшой фирмой 8 ПРОФ

- Взаиморасчеты с поставщиками
- Учет прихода ТМЦ
- Взаиморасчеты с поку...

ООО «Аэроэкспресс»
ООО «Аэроэкспресс»

Отрасль:

Внедренное типовое решение:
1С:ERP. Управление холдингом

· Планирование закупок · Управление закупочными процедурами, включая 223 ФЗ ...

Внедрение ПП «1С:Предприятие 8. Аренда и управление недвижимостью на базе "1С:Бухгалтерия 8"» в компании «Бутово Молл»
ООО «Бутово Молл»

Отрасль:
Недвижимость

Внедренное типовое решение:
1С:Аренда и управление недвижимостью на базе «1С:Бухгалтерия 8»

Управление продажами, логистикой и транспортом (SFM, WMS, TMS):
- Оформление зак...

ООО «ЛИГА-ТРАНС»
ООО «ЛИГА-ТРАНС»

Отрасль:
Профессиональные услуги, бытовое обслуживание

Внедренное типовое решение:
«1С:ERP Управление предприятием 2.1».

- Сделано ТЗ по автоматизации учета МСФО: - Разработана карта бюджета доходо...

ООО «Фипар»
ООО «Фипар»

Отрасль:

Внедренное типовое решение:
1С:Предприятие 8. ERP Управление предприятием 2

Специалисты «Кодерлайн» внедрили «1С:ERP. Управление предприятием 2» и автома...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение