04.02.2020 Денис Белоконенко 31403
Произвольная иерархия в 1С СКД

Содержание

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

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

 

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

 

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


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


ВЫБРАТЬ

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

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

ИЗ

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

    

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


ВЫБРАТЬ

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

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

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

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

ИЗ

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

ГДЕ

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

 

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




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


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

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


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


ВЫБРАТЬ

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

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

ИЗ

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

ВЫБРАТЬ

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

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

ИЗ

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

ГДЕ

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

 

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




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




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


ВЫБРАТЬ

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

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

ИЗ

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

ГДЕ

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

 

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

  


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


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


ВЫБРАТЬ

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

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

ИЗ

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

 

ВЫБРАТЬ

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

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

ИЗ

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

ГДЕ

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

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

 

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

    

ВЫБРАТЬ

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

            NULL

ИЗ

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

    

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




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


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

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

Наши проекты

Московский филиал ООО «Авиакомпания «Икар»
Московский филиал ООО «Авиакомпания «Икар»

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

Внедренное типовое решение:
1С:Зарплата и управление персоналом

Управление персоналом и кадровый учет (HRM) Кадровый учет Расчет зарплаты Рег...

Апгрейд 1С:Бухгалтерия 8 ПРОФ (USB) до версии 1С:Бухгалтерия 8 КОРП (USB)
ООО «Ява Строй»

Отрасль:
Строительство

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

- Создание чистых конфигураций. Внесение изменений в БД ЗУП и новая расчетна...

ПЭК
ПЭК

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

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Перевод зарплатных баз с версии ЗУП 2.5 на версию ЗУП 3.1.
- Сопровождение в п...

ПАО «АрселорМиттал Кривой Рог»
ПАО «АрселорМиттал Кривой Рог»

Отрасль:
Металлургическая промышленность

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

- Кадровый учет
- Расчет зарплаты
- Регламентированная отчетность
- Уч...

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

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

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

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

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

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

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

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

Группа компаний ТМ «Дружба народов»
Группа компаний ТМ «Дружба народов»

Отрасль:
Пищевая промышленность

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

- Переход на новый релиз 2.1 программы «1С:ERP Управление предприятием»
- Разра...

Фирма 1С
Фирма 1С

Отрасль:

Внедренное типовое решение:
1С:Документооборот

- Подготовка функциональной модели прикладного решения «1С:Документооборот...

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

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

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

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

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

Отрасль:

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

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

ООО "НЦКТ"
ООО "НЦКТ"

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

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

Взаиморасчеты с покупателями
Автоматизация бизнес-процессов...

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

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

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

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

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

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

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

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