Быстрое формирование наборов данных Объект схемы СКД

05.07.20

Разработка - СКД

При разработке отчета, использующего наборы данных Объект, зачастую много времени занимает описание самих наборов в схеме СКД. Если таких наборов несколько или количество полей в них достаточно велико, то задача усложняется. В публикации приводится способ сокращения подобных трудозатрат.

Скачать файлы

Наименование Файл Версия Размер
Быстрое формирование наборов данных Объект схемы СКД:
.erf 25,63Kb
9
.erf 25,63Kb 9 Скачать

Предположим, вы разрабатываете отчет на основании работающих в типовой конфигурации «распределенных» запросов. Это такие запросы, текст которых «размазан» по процедуре, а то и нескольким процедурам одновременно (ну вот любят такие подходы некоторые команды). Плюс текст запроса постоянно меняется, а сам запрос периодически выполняется.
Цель таких запросов – собрать в менеджере временных таблиц необходимые для каких-то дальнейших действий данные.

А возможно, у вас есть уже готовый пакет данных в виде таблиц значений, и вы бы хотели использовать его в отчете.

СКД легко позволит это сделать, набор данных Объект подходит великолепно. Только данные менеджера временных таблиц нужно сначала преобразовать в таблицы значений. Это сделать совсем несложно.

Дальше нужно описать таблицы значений и их колонки в схеме СКД. Чтобы не терять зря времени на такую монотонную и скучную операцию – воспользуйтесь следующим программным кодом:

 
 Программный код

Достаточно скормить функции СоздатьСхемуКомпоновкиДанных() ваш менеджер временных таблиц, или структуру с таблицами значений, или просто таблицу или дерево значений, или текст запроса, или сам запрос – вы получите схему компоновки данных, содержащую описание наборов данных:

Наборы легко переносятся между разными схемами банальным копипастом.

На рисунке показана схема, сформированная по запросу из процедуры заполнения квартальной РСВ в ЗУП 3.1, состоящая из 73! временных таблиц.

Отчет, прилагаемый к публикации, иллюстрирует приведенный пример наглядно – формирует и открывает в конструкторе сформированную схему.

Запускать в толстом клиенте. Тестировалось в ЗУП 3.1.14.55 на платформе 8.3.16.1063

За основу взята разработка из публикации Пример универсальной функции для создания схемы компоновки данных (автор dbachinsky).

Для «облагораживания» заголовков формируемых полей в наборах данных использована чуть модифицированная (и не без костылей) функция из публикации Функция Синоним для наименования (автор nick-max).

СКД набор данных объект формирование

См. также

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

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

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

12000 руб.

02.09.2020    101485    561    385    

607

1C:Предприятие для программистов: Запросы и отчеты. Онлайн-интенсив с 27 ноября по 27 декабря 2023г.

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

Данный онлайн-курс предусматривает углубленное изучение языка запросов и возможностей системы компоновки данных, которые понадобятся при разработке отчетов, работающих на платформе “1С:Предприятие” в рамках различных прикладных решений. Курс предназначен для тех, кто уже имеет определенные навыки конфигурирования и программирования в системе “1С:Предприятие”, а также для опытных пользователей различных прикладных решений, которые используют в своей работе отчеты разного назначения. Курс является вторым курсом траектории развития 1С-Разработчика, с углубленным изучением тем "Язык запросов" и "Отчеты", которые были рассмотрены в рамках “Базового курса для начинающих 1С-программистов”.

7500 руб.

04.10.2023    2544    48    0    

47

Модель СКД

Инструментарий разработчика СКД Платформа 1С v8.3 Система компоновки данных Абонемент ($m)

DSL для работы с СКД.

1 стартмани

15.11.2023    3947    10    kalyaka    4    

81

Разрыв страницы в СКД. Легко!

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

Когда отчет надо разделить по страницам, это всегда проблема для разработчика. Поскольку в СКД нет стандартных вариантов, как это сделать. Нашел (на свой взгляд) самое простое и оптимальное решение.

01.09.2023    3178    KVIKS    15    

76

Гибкие отборы через СКД на управляемых формах. Демо-обработка

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

В данной публикации предлагаю вам рабочий пример использования системы компоновки данных для отборов на управляемых формах.

2 стартмани

07.06.2023    4586    26    quazare    7    

46

Вывод элементов иерархии верхнего уровня на СКД

СКД Платформа 1С v8.3 Абонемент ($m)

Как получить родителя первого уровня иерархического справочника с помощью СКД.

1 стартмани

06.06.2023    4212    echo77    6    

72

Обработка результатов запроса произвольными вычисляемыми полями. Обзор некоторых новых функций СКД

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

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

07.02.2023    5502    quazare    7    

38
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. kirill_sh 1 06.07.20 12:26 Сейчас в теме
Интересная статья 👍
2. ixijixi 1687 06.07.20 21:27 Сейчас в теме
Я перешел на использование менеджера временных таблиц в СКД вместо Объекта, гораздо удобнее получается
0x00; Azamatex; sapervodichka; +3 1 Ответить
3. Yashazz 4627 07.07.20 06:53 Сейчас в теме
(2) Далеко не у всех 17-й релиз

А вообще я такое десять лет назад уже активно юзал. Ничего нового под Луной)
5. Алексей Воробьев 287 07.07.20 07:10 Сейчас в теме
(3) Вопрос не в новизне решения :-)
Я взял за основу достаточно старую публикацию, несложное решение из которой использовал не раз, за что благодарен ее автору. Он помог сэкономить мне время.
Я добавил, по сути, к этой публикации несколько строчек. И тоже не только своих.
Если эта моя публикация поможет еще кому-то сэкономить понемногу времени, то буду считать, что цели своей добился...
Fox-trot; +1 Ответить
6. Yashazz 4627 07.07.20 08:24 Сейчас в теме
(5) Тогда будьте любезны указать ссылку на "достаточно старую публикацию", а то слегка так плагиатом попахивает...
8. Алексей Воробьев 287 07.07.20 09:01 Сейчас в теме
(6) Возможно, вы не заметили, но ссылки на использованные публикации, приведены в конце моей с указанием ссылок на профили авторов.
9. Yashazz 4627 07.07.20 09:06 Сейчас в теме
(8) Опаньки. Виноват, и правда проскроллилось как-то. Вопрос снят, извиняюсь.
4. Алексей Воробьев 287 07.07.20 06:58 Сейчас в теме
(2) То, о чем вы говорите, немного "из другой оперы". Временные таблицы из менеджера сейчас (с 8.3.17) можно использовать в запросах наборов данных СКД "без лишних объяснений". Такое использование предполагает дополнительную обработку таблиц в запросах наборов данных.

Чтобы, имея уже готовую таблицу значений, использовать ее в СКД с помощью этой новой возможности, нужно в отдельном запросе перегонять ее во временную таблицу, а потом использовать ее уже в запросе набора данных. "Напрямую" в виде набора данных ее использовать не получится.
Здесь же речь о возможности быстро сформировать наборы данных СКД на основании готовых таблиц. Или, в случае использования менеджера временных таблиц, дополнительная обработка которых не требуется, выгрузить эти таблицы в таблицы значений и опять таки использовать их непосредственно в виде наборов данных СКД.
11. ixijixi 1687 07.07.20 12:47 Сейчас в теме
(4)
в отдельном запросе перегонять ее во временную таблицу, а потом использовать ее уже в запросе набора данных. "Напрямую" в виде набора данных ее использовать не получится

Ну, Вы прям жути нагнали)) Фактически все действия займут 4 строки кода:
Запрос = Новый Запрос("ВЫБРАТЬ * ИЗ &ТЗ КАК Т");
Запрос.МенеджерВременныхТаблиц = МенеджерВременныхТаблиц;
Запрос.УстановитьПараметр("ТЗ", ТЗ);
Запрос.Выполнить();

Всё, можно использовать "в виде набора данных".
12. Алексей Воробьев 287 07.07.20 12:57 Сейчас в теме
(11) Вопрос не в перегонке, тут действительно все тривиально. А в последующем использовании в наборе: временная таблица есть в МВТ, а описания ее полей в наборе нет.
Нужно в наборе-запросе рисовать запрос к таблице МВТ, расписывая "звездочку" во все нужные поля и автозаполнять поля набора. Или воспользоваться методом из публикации, чтобы заполнить поля из ТЗ, не делая промежуточных движений с МВТ...
15. ixijixi 1687 07.07.20 14:43 Сейчас в теме
(12) Да, тут соглашусь
14. Yashazz 4627 07.07.20 14:25 Сейчас в теме
(11) Нифига. Надо ещё проверить типизацию колонок и содержимое, а то многим из наполняющего таблицу значений МВТ подавиться может, а кое-что может исказить.
Алексей Воробьев; +1 Ответить
16. Алексей Воробьев 287 07.07.20 15:06 Сейчас в теме
(14) Согласен, не учел такие доп. расходы времени. Просто расписать "звездочку" действительно мало...
7. Yashazz 4627 07.07.20 08:27 Сейчас в теме
Ну и нафига все эти ФОМСы, непонятно, кому оно надо... Делаете репост, так хоть выкиньте неуниверсальное. А то как дипломник, скачавший чужой диплом и выдающий его за свой, и даже не озаботившийся убрать совсем посторонние фрагменты.

...и не стыдно людям такое выкладывать, вот ё-моё...

А мой код 10-летней давности вот: https://infostart.ru/public/1133780/ - как ни странно, актуален и полезен по сей день.
10. Алексей Воробьев 287 07.07.20 09:21 Сейчас в теме
(7) Это не "неуниверсальное". Этот код - костыли, про которые я упоминаю в конце публикации. И эти костыли нужны в рамках рассмотренного мной примера в файле публикации. И нужны в опубликованном коде, для понимания того, что именно за "костыли" я упомнянул.
Я не позиционировал это решение как однозначно универсальное :-) Только, возможно, за это и стыдно - что не нашел универсального решения без "костылей".

Боюсь, что ваш негатив обусловлен тем, что вы не стали просматривать короткую публикацию до конца.

Я однозначно рад актуальности вашего кода 10-летней давности. Меня, более того, это восхищает.
Особенно в рамках того печального соображения, что имея опыт разработки только в 1С более 15 лет (с 7.7 еще) я все еще часто хочу и иногда переписываю свой код всего лишь годовалой давности просто потому, что случайно на него напоролся и он мне перестал нравится. Ну, это когда времени хватает...

В приведенной вами вашей же публикации с актуальным и полезным кодом отдельного внимания заслуживают некоторые комментарии. И ваши ответы на них тоже. Весьма экставагантные подходы к критике "универсального" кода.
Но, в любом случае, пред вашим вкладом в развитие сообщества - снимаю шляпу...
13. Yashazz 4627 07.07.20 14:23 Сейчас в теме
(10)
я все еще часто хочу и иногда переписываю свой код всего лишь годовалой давности просто потому, что случайно на него напоролся и он мне перестал нравится. Ну, это когда времени хватает...
о да, это и у меня любимое занятие, но именно когда сил и времени хватает. Знакомое явление. Я даже как-то свой код, вытащенный с 7.5 на 7.7, писанный ещё году в 98-м, заманьячился на таблицы значений переводить)
Оставьте свое сообщение