15.05.2022 Владимир Быков 31959
ДобавитькДате запрос в 1С

Содержание:

1.       Описание функции языка запроса ДобавитьКДате

2.       Работа с функцией языка запроса ДобавитьКДате в Конструкторе запросов 1С 8.3  

 

1.     Описание функции языка запроса ДобавитьКДате

 


ДобавитьКДате

 

ДобавитьКДате(DATEADD) - Функция предназначена для прибавления к дате некоторой величины.

Описание функции.

Параметры

<Дата> - тип Дата, выражение (функции и параметры языка запросов)



ДАТАВРЕМЯ

 

·        ДАТАВРЕМЯ(<Год>,<Месяц>,<День>,<Час>,<Минута>,<Секунда>) – функция языка запросов.



Функция языка запросов ДатаВремя

 

·        &ДатаВремя – параметр языка запросов.

 


Параметр языка запросов ДатаВремя

 

·        <Тип> - строка без кавычек. Варианты: Секунда, Минута, Час, День, Неделя, Месяц, Квартал, Год, Декада, Полугодие.



ДабавитьКДатеДатаВремя

 

<Количество> - тип Число, может быть число, выражение (функция языка запросов).  


2.     Работа с функцией языка запроса ДобавитьКДате в Конструкторе запросов 1С 8.3


Попрактиковаться можно с помощью управляемой консоли запросов.



Управляемая консоль запросов

 

После того как открыли консоль запросов в 1С 8.3 «Предприятие» в «пользовательском режиме». В той части окна консоли запросов, где пишется текст запроса вызвать конструктор запросов (позволяет сделать контекстное меню). Все функции языка запросов находятся в правой части окна. Находим в иерархическом древовидном списке функцию ДОБАВИТЬКДАТЕ и переносим её с помощью мыши в поле, где пишем код.


Теперь можно выбрать какую-нибудь таблицу (например, справочник), вывести поле (обязательно, хотя бы одно). Потом создать своё поле с функцией ДОБАВИТЬКДАТЕ, для быстроты можно на закладке «Дополнительно» установить выборку записей «Первые» с значением 1. Проверить результат.


Задание. В торговой компании сотрудникам возраст, которых достиг 30 лет начисляются бонусы на дисконтную карту. А также сотрудникам, которые отработали в компании 5 лет также начисляются бонусы на дисконтную карту т.к. статистика показала, что 60% сотрудников меняют место работы срок стажа которых, не превышает 5 лет. Таким образом компания решила поощрить сотрудников за постоянство. Появилась необходимость определить возраст сотрудников и их стаж работы.


Для этого потребуется создать обработку и написать код. Для примера использовано прикладное решение 1С Зарплата и управление персоналом КОРП, редакция 3.1 (3.1.15.96), демоверсия. Ниже написан основной код отчета.

    

&НаСервере

Процедура СформироватьНаСервере()

 

                Запрос = Новый Запрос;

                Запрос.Текст= "ВЫБРАТЬ РАЗРЕШЕННЫЕ

                               |              Сотрудники.Ссылка КАК Сотрудник

                               |ИЗ

                               |              Справочник.Сотрудники КАК Сотрудники

                               |ГДЕ

                               |              Сотрудники.ПометкаУдаления = ЛОЖЬ"

                ;

               

                ВсеСотрудники= Запрос.Выполнить().Выгрузить();

                              

                // Получить кадровые данные

КадровыеДанные = КадровыйУчет.КадровыеДанныеСотрудников(Истина, ВсеСотрудники.ВыгрузитьКолонку("Сотрудник"),

                "Организация,ФизическоеЛицо,ДатаУвольнения,ДатаПриема", УстановитьДемоДату);

               

                КадровыеДанные.Колонки.Добавить("ДатаРождения", Новый ОписаниеТипов("Дата"));

               

                Для Каждого СтрокаКадровыеДанныеИзКадровыеДанныеЦикл

СтрокаКадровыеДанные.ДатаРождения= СтрокаКадровыеДанные.ФизическоеЛицо.ДатаРождения;             

                КонецЦикла;

               

                Результат.Очистить();

               

                ОтчетОбъект= РеквизитФормыВЗначение("Объект");

                Макет = ОтчетОбъект.ПолучитьМакет("Макет");

               

                ОбластьШапка= Макет.ПолучитьОбласть("Шапка");

                Результат.Вывести(ОбластьШапка);

               

                ОбластьСтрока= Макет.ПолучитьОбласть("Строка");

               

                ДемонстрационныйЗапрос= Новый Запрос;

                ДемонстрационныйЗапрос.Текст="ВЫБРАТЬ

                                               |            КадровыеДанные.Организация КАК Организация,

                                               |            КадровыеДанные.ФизическоеЛицо КАК ФизическоеЛицо,

                                               |            КадровыеДанные.ДатаУвольнения КАК ДатаУвольнения,

                                               |            КадровыеДанные.ДатаПриема КАК ДатаПриема,

                                               |            КадровыеДанные.ДатаРождения КАК ДатаРождения,

                                               |            ДОБАВИТЬКДАТЕ(КадровыеДанные.ДатаРождения, ГОД, 30) КАК ВозрастСотрудника,

                                               |            ДОБАВИТЬКДАТЕ(КадровыеДанные.ДатаПриема, ГОД, 5) КАК СтажРаботы

                                               |ПОМЕСТИТЬ ВТКадровыеДанные

                                               |ИЗ

                                               |            &КадровыеДанные КАК КадровыеДанные

                                               |ГДЕ

                                               |            КадровыеДанные.ДатаУвольнения = ДАТАВРЕМЯ(1, 1, 1, 0, 0, 0)

                                               |;

                                               |

                                               |////////////////////////////////////////////////////////////////////////////////

                                               |ВЫБРАТЬ

                                               |            ВТКадровыеДанные.Организация КАК Организация,

                                               |            ВТКадровыеДанные.ФизическоеЛицо КАК ФизическоеЛицо,

                                               |            ВТКадровыеДанные.ДатаУвольнения КАК ДатаУвольнения,

                                               |            ВТКадровыеДанные.ДатаПриема КАК ДатаПриема,

                                               |            ВТКадровыеДанные.ДатаРождения КАК ДатаРождения,

                                               |            ВТКадровыеДанные.ВозрастСотрудника КАК ВозрастСотрудника,

                                               |            ВТКадровыеДанные.СтажРаботы КАК СтажРаботы

                                               |ИЗ

                                               |            ВТКадровыеДанные КАК ВТКадровыеДанные";

               

                ДемонстрационныйЗапрос.УстановитьПараметр("КадровыеДанные",КадровыеДанные);

                ДемонстрационныйЗапрос.УстановитьПараметр("ТекущаяДата",УстановитьДемоДату);

                РезультатДемоЗапроса=ДемонстрационныйЗапрос.Выполнить().Выбрать();

 

                Пока РезультатДемоЗапроса.Следующий()Цикл

                              

                               Исполнилось30Лет = Истина;

                               Отработал5Лет = Истина;

                              

                               // Отметить сотрудников, которым не исполнилось 30 лет

                               Если НачалоМесяца(УстановитьДемоДату)<>

                                               НачалоМесяца(РезультатДемоЗапроса.ВозрастСотрудника) Тогда

                                               Исполнилось30Лет = Ложь;         

                               КонецЕсли;

                              

                               // Отметить сотрудников, которые не отработали 5 лет или

                               // отработали более и уже получили бонусы

                               Если Год(УстановитьДемоДату) <>Год(РезультатДемоЗапроса.СтажРаботы) Тогда

                                               Отработал5Лет = Ложь;

                               КонецЕсли;

                              

                               // Исключить из отчета сотрудников, которым не исполнилось 30 лет

                               // Исключить из отчета сотрудников, которые не отработали 5 лет или

                               // отработали более и уже получили бонусы

                               Если Не Исполнилось30Лет И Не Отработал5Лет Тогда

                                               Продолжить;     

                               КонецЕсли;

                              

                               ОбластьСтрока.Параметры.ФИО=РезультатДемоЗапроса.ФизическоеЛицо;

                               ОбластьСтрока.Параметры.БонусЗаСтаж                =Отработал5Лет;

                               ОбластьСтрока.Параметры.БонусЗаВозраст          =Исполнилось30Лет;

                              

                               Результат.Вывести(ОбластьСтрока);

                              

                КонецЦикла;

               

КонецПроцедуры

 

После создания интерфейса, написания кода, получается результат.



Результат написания кода в 1С Зарплата и управление персоналом КОРП

    

В написании отчета использовалась функция ДобавитькДатев запросе (см. в конструкторе запроса 1С 8.3 ЗУП).

 


ИспользованиеДобавитьКДате в запросе 1С

 

Система, выполнив запрос, обходит выборку, где проверяет условия стажа работы и возраста сотрудников. Данный пример приведен для представления, как можно использовать данную функцию ДобавитьКДате в запросе в 1С.

    

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

Владимир Быков

Наши проекты

Разработка функциональных требований к информсистеме на базе «1С:Управление холдингом 8»
ФГУП «СВЯЗЬ-безопасность»

Отрасль:
Охранные услуги

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

- Зафиксировали процессы по блокам бухгалтерского, налогового учета, казнач...

ПЭК
ПЭК

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

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

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

Автоматизация контроля исполнительской дисциплины на базе ПП «1С:Документооборот 8 ПРОФ»
ООО «ФСК Лидер»

Отрасль:
Строительство и девелопмент

Внедренное типовое решение:
1С:Документооборот 8 ПРОФ

- Делопроизводство;
- Учет и хранение документов;
- Учет и контроль исполне...

Внедрение «1С:Бухгалтерия 8 ПРОФ» в компании «Мостехника»
ООО «Мостехника»

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

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

Документооборот (ECM):
- Учет рабочего времени;
Управление персоналом и ка...

Автоматизация торгового учета на базе "1С:Управление торговлей"
ООО «ТЕЛЕВЕС РУСС»

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

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

- Управление складскими запасами;
- Оформление заказов покупателей;
- Пла...

ОАО «Интер РАО – Электрогенерация»
ОАО «Интер РАО – Электрогенерация»

Отрасль:
Электрогенерация

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

Для работы 2500 пользователей в 9 часовых поясах организована территориально-...

Внедрение ПП "1С:Бухгалтерия 8 ПРОФ" в ООО Фирма «Бисер»
ООО фирма «Бисер»

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

Внедренное типовое решение:
1С:Бухгалтерия 8 ПРОФ

Финансы, управленческий учет, мониторинг показателей:
- Налоговый учет...

Автоматизация системы учета продаж газа на базе «1С:ERP Управление предприятием 2.0»
ООО «Эйр Продактс Газ»

Отрасль:
Производство промышленных газов

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

- Расчеты с контрагентами;
- Производственные операции;
- Управление скла...

ООО «Вистеон Автоприбор Электроникс»
ООО «Вистеон Автоприбор Электроникс»

Отрасль:

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

- Управленческий учет; - Расчет зарплаты; - Логистика адресного склада; - Учет ...

ООО ХДМ Рус
ООО ХДМ Рус

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

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

Бухгалтерский учет Банк и касса Расчеты с контрагентами Торговые операции ...

Автоматизация интеграции с информсистемами клиентов на базе «1С:Предприятие 8. WMS Логистика. Управление складом»
ОАО «Фрейт Линк»

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

Внедренное типовое решение:
«1С:Предприятие 8. WMS Логистика. Управление складом»

– Управление складскими запасами;
– Оформление заказов покупателей;
– ...

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

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

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

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

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

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

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

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