Запрос для выбора категорий сотрудников по физ лицу для ЗиУП 2.5

25.11.10

Разработка - Запросы

Запрос позволяет выбрать физ. лицо, организацию, категории сотрудников и коэффициент, на который нужно умножить значения сумм (например начисленного НДФЛ для физ.лица). Мы используем категории сотрудников для разделения зарплаты по проектам. В результат включаются только сотрудники, работавшие за заданный период как по трудовому договору, так и по договорам ГПХ.

Просто, чтобы не забыть, может кому-то пригодится:

 

ВЫБРАТЬ
    Работники.Сотрудник.Организация КАК Организация,
   
Работники.Сотрудник.ФизЛицо КАК ФизЛицо,
   
КатегорииОбъектовРаботники.Категория КАК Категория,
   
Работники.Коэффициент КАК Коэффициент
ИЗ
(
   
ВЫБРАТЬ
        РаботающиеСотрудники.Сотрудник КАК Сотрудник,
       
1/Количество(ЕстьNULL(КатегорииОбъектов.Категория,ЗНАЧЕНИЕ(Справочник.КатегорииОбъектов.ПустаяСсылка))) КАК Коэффициент
    ИЗ (
       
ВЫБРАТЬ Сотрудник
        ИЗ РегистрСведений.РаботникиОрганизаций.СрезПоследних(&КонецПериода) КАК РаботающиеНаНачалоПериода
        ГДЕ РаботающиеНаНачалоПериода.ПричинаИзмененияСостояния <> &Увольнение

        ОБЪЕДИНИТЬ
        выбрать Сотрудник
        ИЗ РегистрСведений.РаботникиОрганизаций.СрезПоследних(&КонецПериода) КАК РаботающиеНаКонецПериода
        ГДЕ РаботающиеНаКонецПериода.ПричинаИзмененияСостояния = &Увольнение И  РаботающиеНаКонецПериода.Период МЕЖДУ &НачалоПериода И &КонецПериода

        ОБЪЕДИНИТЬ
        ВЫБРАТЬ Сотрудник
        ИЗ Документ.ДоговорНаВыполнениеРаботСФизЛицом КАК РаботающиеПоДоговорамГПХ
        ГДЕ РаботающиеПоДоговорамГПХ.ДатаНачала <= &КонецПериода И РаботающиеПоДоговорамГПХ.ДатаОкончания >= &НачалоПериода
    ) КАК РаботающиеСотрудники
    ЛЕВОЕ СОЕДИНЕНИЕ
        РегистрСведений.КатегорииОбъектов КАК КатегорииОбъектов
        ПО КатегорииОбъектов.Объект = РаботающиеСотрудники.Сотрудник
    СГРУППИРОВАТЬ ПО
       
РаботающиеСотрудники.Сотрудник
) КАК Работники
ЛЕВОЕ СОЕДИНЕНИЕ
    РегистрСведений.КатегорииОбъектов КАК КатегорииОбъектовРаботники
    ПО КатегорииОбъектовРаботники.Объект = Работники.Сотрудник
упорядочить по Работники.Коэффициент

 

Вариант для отчётов типа Анализ начисленных налогов и взносов, - чтобы попадали доначисленные суммы по уволенным людям, добавлен "взгляд назад" на 3 месяца, а чтобы они не множились, немного усложнён расчёт коэффициента:

 

   ВЫБРАТЬ
    Работники.Сотрудник.Организация КАК Организация,
   
Работники.Сотрудник.ФизЛицо КАК ФизЛицо,
   
КатегорииОбъектовРаботники.Категория КАК Категория,
   
Работники.Коэффициент
ИЗ
(
   
ВЫБРАТЬ
        Подгруппа.ФизЛицо КАК ФизЛицо,
       
Подгруппа.Организация КАК Организация,
       
Максимум(Подгруппа.Сотрудник) КАК Сотрудник,
       
Количество(Подгруппа.Сотрудник)/Сумма(Подгруппа.КоличествоКатегорий) КАК Коэффициент
    ИЗ (
       
ВЫБРАТЬ
            РаботающиеСотрудники.Сотрудник.ФизЛицо КАК ФизЛицо,
           
РаботающиеСотрудники.Сотрудник.Организация КАК Организация,
           
РаботающиеСотрудники.Сотрудник КАК Сотрудник,
           
Количество(ЕстьNULL(КатегорииОбъектов.Категория,ЗНАЧЕНИЕ(Справочник.КатегорииОбъектов.ПустаяСсылка))) КАК КоличествоКатегорий
        ИЗ (
           
ВЫБРАТЬ Сотрудник
            ИЗ РегистрСведений.РаботникиОрганизаций.СрезПоследних(&КонецПериода) КАК РаботающиеНаНачалоПериода
            ГДЕ РаботающиеНаНачалоПериода.ПричинаИзмененияСостояния <> &Увольнение

            ОБЪЕДИНИТЬ
            выбрать Сотрудник
            ИЗ РегистрСведений.РаботникиОрганизаций.СрезПоследних(&КонецПериода) КАК РаботающиеНаКонецПериода
            ГДЕ РаботающиеНаКонецПериода.ПричинаИзмененияСостояния = &Увольнение И  РаботающиеНаКонецПериода.Период МЕЖДУ ДобавитьКДате(&НачалоПериода,Месяц,-3) И &КонецПериода

            ОБЪЕДИНИТЬ
            ВЫБРАТЬ Сотрудник
            ИЗ Документ.ДоговорНаВыполнениеРаботСФизЛицом КАК РаботающиеПоДоговорамГПХ
            ГДЕ РаботающиеПоДоговорамГПХ.ДатаНачала <= &КонецПериода И РаботающиеПоДоговорамГПХ.ДатаОкончания >= &НачалоПериода
        ) КАК РаботающиеСотрудники
        ЛЕВОЕ СОЕДИНЕНИЕ
            РегистрСведений.КатегорииОбъектов КАК КатегорииОбъектов
            ПО КатегорииОбъектов.Объект = РаботающиеСотрудники.Сотрудник
        СГРУППИРОВАТЬ ПО
           
РаботающиеСотрудники.Сотрудник
    ) КАК Подгруппа
    СГРУППИРОВАТЬ ПО
       
Подгруппа.Организация,
       
Подгруппа.ФизЛицо
) КАК Работники
ЛЕВОЕ СОЕДИНЕНИЕ
    РегистрСведений.КатегорииОбъектов КАК КатегорииОбъектовРаботники
    ПО КатегорииОбъектовРаботники.Объект = Работники.Сотрудник



См. также

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

Инструментарий разработчика Роли и права Запросы СКД Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 руб.

02.09.2020    119906    656    389    

701

Для чего используют конструкцию запроса "ГДЕ ЛОЖЬ" в СКД на примере конфигурации 1С:ERP

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных 1С:ERP Управление предприятием 2 Бесплатно (free)

В типовых конфигурациях разработчики компании 1С иногда используют в отчетах, построенных на СКД, такую конструкцию, как "ГДЕ ЛОЖЬ". Такая конструкция говорит о том, что данные в запросе не будут получены совсем. Для чего же нужен тогда запрос?

13.02.2024    5618    KawaNoNeko    23    

23

Набор-объект для СКД по тексту или запросу

Запросы СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Есть список полей в виде текста, или запрос - закидываем в набор СКД.

1 стартмани

31.01.2024    1964    2    Yashazz    0    

29

Запрос 1С copilot

Инструментарий разработчика Запросы Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Пишем на человеческом языке, что нам надо, и получаем текст запроса на языке 1С. Используются большие языковые модели (LLM GPT) от OpenAI или Яндекс на выбор.

5 стартмани

15.01.2024    6089    29    mkalimulin    23    

48

PrintWizard: поддержка представлений ЗУП в конструкторе

Инструментарий разработчика Запросы Платформа 1С v8.3 Бесплатно (free)

Одной из интересных задач, стоящих в процессе разработки, была поддержка механизма представлений в ЗУП. Но не просто возможность исполнения запросов с ними. Основная проблема была в том, чтобы с ними было удобно работать, а именно: создавать, модифицировать и отлаживать. Кратко о том, что в итоге получилось...

14.12.2023    1714    vandalsvq    7    

28

Объектная модель запроса "Схема запроса" 2

Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

Далеко уже не новый тип данных "Схема запроса". Статья о том, как использовать его "попроще". Примеры создания текста запроса с нуля и изменение имеющегося запроса.

06.12.2023    5282    user1923546    26    

43

Начните уже использовать хранилище запросов

HighLoad оптимизация Запросы

Очень немногие из тех, кто занимается поддержкой MS SQL, работают с хранилищем запросов. А ведь хранилище запросов – это очень удобный, мощный и, главное, бесплатный инструмент, позволяющий быстро найти и локализовать проблему производительности и потребления ресурсов запросами. В статье расскажем о том, как использовать хранилище запросов в MS SQL и какие плюсы и минусы у него есть.

11.10.2023    15954    skovpin_sa    14    

97
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. alexk-is 6533 14.10.10 08:53 Сейчас в теме
Текст запроса в публикации можно раскрасить
4. boogie 489 03.11.10 17:11 Сейчас в теме
2. artbear 1447 03.11.10 16:40 Сейчас в теме
(0) "Объединить все" побыстрее будет :) Да и временные таблицы лучше юзать вместо нескольких уровней вложенности.

А вообще нафига выкладывать на сайт подобный запрос?
У каждого разработчика подобных запросов целая корзина :)
3. boogie 489 03.11.10 17:09 Сейчас в теме
(2) я ж говорю для себя, мне часто бывает надо для кадров.
5. Filys_Fog 13 04.05.11 09:02 Сейчас в теме
Незнаю кому как а мне пригодилось. спасибо...
Оставьте свое сообщение