Произвольная иерархия в 1С СКД

0
1762
04.02.2020 Денис Белоконенко

Содержание

1.    Построение иерархии ссылочного типа

2.    Пример с реквизитом «Спецификация» справочника Номенклатура  

 

1.      Построение иерархии ссылочного типа

 

Для построения иерархии для ссылочного типа в 1С СКД в настройках группировки проставляется «Иерархия» либо «Только иерархия». При таком установке СКД создает невидимый для пользователя дополнительный большой набор данных.


Приведем простой пример. Есть набор «Остатки» с запросом:


ВЫБРАТЬ

            ТоварыНаСкладахОстатки.НоменклатураКАК Номенклатура,

            ТоварыНаСкладахОстатки.ВНаличииОстатокКАК Остаток

ИЗ

            РегистрНакопления.ТоварыНаСкладах.ОстаткиКАК ТоварыНаСкладахОстатки

    

Для вывода иерархии СКД создаст дополнительный набор вида:


ВЫБРАТЬ

            Номенклатура.СсылкаКАК Номенклатура,

            Номенклатура.ПредставлениеКАК Представление,

            Номенклатура.РодительКАК Родитель,

            Номенклатура.НаименованиеКАК Наименование

ИЗ

            Справочник.НоменклатураКАК Номенклатура

ГДЕ

            Номенклатура.СсылкаВ(&Ссылки)

 

Помимо этого будут прописаны связи между этими наборами.




Первая связывает номенклатуру между двумя наборами. Вторая делает связь с самим собой, между родителем (т.е. группой) и номенклатурой.


Обратим внимание на присутствие параметра Ссылки во втором наборе и в связи. Он нужен, чтобы запрос сформировался не по всей номенклатуре, а только для той, что выводится в отчете.

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


Приведем пример. Нужно по остаткам номенклатуры создать иерархию, по созданному реквизиту «Номенклатура разборки». «Номенклатура разборки» имеет тот же тип номенклатуры, причем он тоже может иметь свою номенклатуру разборки. Создадим два набора данных.


ВЫБРАТЬ

            ТоварыНаСкладахОстатки.НоменклатураКАК Номенклатура,

            ТоварыНаСкладахОстатки.ВНаличииОстатокКАК Остаток

ИЗ

            РегистрНакопления.ТоварыНаСкладах.ОстаткиКАК ТоварыНаСкладахОстатки

ВЫБРАТЬ

            Номенклатура.СсылкаКАК Номенклатура,

            Номенклатура.НоменклатураРазборкиКАК Родитель

ИЗ

            Справочник.НоменклатураКАК Номенклатура

ГДЕ

            Номенклатура.СсылкаВ(&Ссылки)

 

Соединим их по аналогии с прошлым примером.




Формируем отчет. Получим:




Тут есть одно «но». Механизм отбора «В группе» по номенклатуре будет работать некорректно. Чтобы это исправить нужно добавить еще один набор вида:


ВЫБРАТЬ

            Номенклатура.СсылкаКАК Номенклатура,

            Номенклатура.НоменклатураРазборкиКАК Родитель

ИЗ

            Справочник.НоменклатураКАК Номенклатура

ГДЕ

                        Номенклатура.НоменклатураРазборкиВ(&НоменклатураРазборки)

 

Делаем связь между собой. В источнике у нас будет «Номенклатура», в приемнике «Родитель». Указываем параметр. В главном наборе данных нужно будет указать напротив «Номенклатуры» проверку иерархии. Указываем набор, который только что создали, и параметр. Отчет готов.  

  


2.  Пример с реквизитом «Спецификация» справочника Номенклатура


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


ВЫБРАТЬ

            ТоварыНаСкладахОстатки.НоменклатураКАК Номенклатура,

            ТоварыНаСкладахОстатки.ВНаличииОстатокКАК Остаток

ИЗ

            РегистрНакопления.ТоварыНаСкладах.ОстаткиКАК ТоварыНаСкладахОстатки

 

ВЫБРАТЬ

            Номенклатура.СсылкаКАК Номенклатура,

            Номенклатура.СпецификацияКАК Спецификация

ИЗ

            Справочник.Номенклатура КАК Номенклатура

ГДЕ

            Номенклатура.СсылкаВ(&Ссылки)

            И НЕ Номенклатура.ЭтоГруппа

 

ОБЪЕДИНИТЬ ВСЕ

    

ВЫБРАТЬ

            Спецификация.Ссылка,

            NULL

ИЗ

            Справочник.СпецификацияКАК Спецификация

    

Связи будут выглядеть вот так:




Вот таким образом можно создавать произвольную иерархию в 1С СКД.


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

Денис Белоконенко.

Задать вопрос автору статьи
Тема вопроса*
Ваше имя*
E-mail или телефон*
Ваш вопрос*
 

Добавить комментарий
Текст сообщения*
Защита от автоматических сообщений
 
Теги
#1С: CRM #1С: ERP #1С: ERP Управление строительной организацией #1С: ERP. Управление буровой компанией #1С: WMS Управление складом #1С: Аренда и управление недвижимостью #1С: БУХ #1С: Договорчики #1С: Документооборот #1С: ЗУП #1С: Интеграция #1С: КА #1С: Колледж #1С: Конвертация данных #1С: Модули #1С: Платформа #1С: Розница #1С: Сценарное тестирование #1С: ТОИР #1С: УАТ #1С: УКФ #1С: Университет #1С: УНФ #1С: УПП #1С: Управление строительной организацией #1С: УТ #1С: УХ #1С:ERP #1С:БГУ #1С.6-НДФЛ #ADO #APACHE #API #canonical #com-объекты #Excel #Excel в 1С #GoogleDrive #HTTP #ITIL #Koderline: Управление медиа-холдингом #Koderline: Управление проектами строительства скважин #LINUX #MS SQL Server #WEB #WEB-сервисы 1С #Word #XML #Администрирование 1С #акты в 1С #Безопасность сервера #Бесшовная интеграция #БИТ.Финанc #Битрикс24 #Блокировки в 1С #БСП #БУ #Бурение скважин #Бюджетирование #Внедрение #Внедрение ERP #Закрытие месяца #Запросы 1С #Интеграция 1С #КАК ОТРАЖАЮТСЯ ТОВАРЫ В ПУТИ 1С #Как сделать в 1С #Конвертация данных #Корпоративное сопровождение #Лизинг #Лицензии 1С #Механизм Анализа Данных в 1С #Моделирование #Модуль Диадок #МСФО #Налоги #Обмен между базами #Обновления #Оптимизация #Отпуск #Отчетность #Отчеты в 1С #Оценка задач #Перенос данных #Планирование #Полезные обработки #Правила обмена #предопределенные элементы справочников #Проводки 1С #Программирование в 1С #Программные права #Продажи #Производство #Работа с объектами в 1С #Расширение конфигурации #РСБУ #СКД #Соединение COM в 1С платформе #Сравнение конфигураций #Тестирование 1С #Техническое задание #Торговое оборудование #Транспортная логистика #Управление проектами #Финансовый учет #Хранилище настроек #Ценообразование #Экзамен 1С #Яндекс.Касса Email или телефон Работа с объектами в 1С Функциональные опции в 1С
Услуги программиста 1С
Получите специалиста  
для решения всех задач
в области 1С
Программы 1С
Цены и подробное описание программ 1С:Предприятие 8.