Как в динамический список управляемой формы документа добавить отбор по реквизиту табличной части этого документа?

15.11.13

Разработка - Механизмы платформы 1С

Как сделать, чтобы по кнопке "Настроить список" в доступных полях элементов коллекции отбора появилось поле для отбора по табличной части?

Это возможно почти без программирования, далее рассмотрим на примере в картинках. Есть некий документ, установим для его формы списка флаг произвольного запроса:

Структура документа   Установка флага произвольного запроса

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

Конструктор запроса по умолчанию

После чего нужно добавить отдельными таблицами нужные нам табличные части:

Добавление табличной части

Подключаем левым соединением табличную часть к основной таблице документа по ссылке:

Установка связей

Теперь группируем все поля, здесь полей табличной части быть не должно:

Группировка полей

После этого заходим на закладку "Компоновка данных", "Условия" и добавляем нужные в отборе поля:

Добавление полей в отборы

Нажимаем "ОК" и видим как выглядит готовый текст запроса:

Текст запроса

Если перейти тут же на закладку "Настройки", то увидим новые добавленные поля отбора:

Настройка отбора

Обратите внимание на то, что реквизит "Подразделение" присутствует как в шапке, так и в табличной части, а в доступных полях отбора всего одно поле, и в такой реализации будет установлен отбор по реквизиту табличной части. Если же нам нужен отбор и по подразделению из шапки, то нужно просто задать другое имя отбора для табличной части:

Установка псевдонима для отбора

И вот как стал выглядеть текст запроса:

Измененный текст запроса

В настройках видно как изменилось имя поля отбора табличной части и вернулось поле отбора по шапке документа:

Измененные поля отбора

Ну, и вот так это выглядит в пользовательском режиме:

Пользовательский режим

Вероятно, также можно разнообразить дополнительные поля отбора, подключая левым соединением любые таблицы данных, лишь бы было поле связи, и добавляя поля таблиц в поля условий компоновки данных. Но, я это не проверял, кому интересно можете поэкспериментировать.

отбор по реквизиту табличной части

См. также

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор?

Обмен между базами 1C Администрирование СУБД Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В платформе 8.3.17 появился замечательный механизм «Сервисы интеграции». Многие считают, что это просто коннектор 1С:Шины. Так ли это?

11.03.2024    4512    dsdred    53    

71

Как готовить и есть массивы

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Все мы используем массивы в своем коде. Это один из первых объектов, который дают ученикам при прохождении обучения программированию. Но умеем ли мы ими пользоваться? В этой статье я хочу показать все методы массива, а также некоторые фишки в работе с массивами.

24.01.2024    5289    YA_418728146    25    

63

Планы обмена VS История данных

Обмен между базами 1C Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Вы все еще регистрируете изменения только на Планах обмена и Регистрах сведений?

11.12.2023    6408    dsdred    36    

111

1С-ная магия

Механизмы платформы 1С Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    18473    SeiOkami    46    

118

Дефрагментация и реиндексация после перехода на платформу 8.3.22

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Начиная с версии платформы 8.3.22 1С снимает стандартные блокировки БД на уровне страниц. Делаем рабочий скрипт, как раньше.

14.09.2023    12087    human_new    27    

74

Валидация JSON через XDTO (включая массивы)

WEB-интеграция Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    8819    YA_418728146    6    

141

Внешние компоненты Native API на языке Rust - Просто!

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

Внешние компоненты для 1С можно разработывать очень просто, пользуясь всеми преимуществами языка Rust - от безопасности и кроссплатформенности до удобного менеджера библиотек.

20.08.2023    6279    sebekerga    54    

94

Все скопируем и вставим! (Буфер обмена в 1С 8.3.24)

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

Рассмотрим новую возможность 8.3.24 и как её можно эффективно использовать

27.06.2023    15984    SeiOkami    31    

103
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Armando 1399 15.11.13 23:21 Сейчас в теме
В запросе соединение надо в фигурные скобки заключить, иначе будете иметь соединение даже при отключенном отборе, что для динамических списков бывает болезненно. И вместо группировки лучше использовать "Различные". На производительность это скорее всего не повлияет, но смотрится лучше, и методически правильнее.
ErrorEd88; nekit_rdx; 1cprogr_nsk; Vladimir Litvinenko; +4 Ответить
8. nixel 1403 21.11.13 14:56 Сейчас в теме
(1) Armando, вопрос сравнения производительности и выбора конструкций distinct (различные) и group by довольно часто поднимается и однозначного ответа на него нет. Уж больно все разнится на разных субд и разных запросах :)
Да, "различные" проще и красивее выглядит, но не всегда быстрее :)
9. Armando 1399 21.11.13 15:14 Сейчас в теме
(8) nixel, я тоже точно не знаю. Надо план запроса смотреть. Просто привык, что вместе с группировкой используются агрегатные функции. А тут конкретно уникальные строки получить надо.
2. Mart 105 16.11.13 14:31 Сейчас в теме
Да, согласен. Спасибо за замечание.
3. AltF1 8 18.11.13 14:19 Сейчас в теме
Вот оно, спасибо автору за раскрытие.
4. mxm2 1263 20.11.13 08:37 Сейчас в теме
Вроде как всегда хватало просто Ctrl + F на соответствующей табличной части и получим отбор по одному полю.
Ctrl + Q - отключение отбора.
5. Mart 105 20.11.13 12:57 Сейчас в теме
(4) mxm2, Верно, эти комбинации клавиш действительно управляют отбором табличной части самого документа, но здесь речь про журнал(список) документов, в котором нужно управлять отбором по полям реквизитов табличных частей документа.
6. mxm2 1263 20.11.13 13:39 Сейчас в теме
(5) Каюсь... Не въехал сразу. )
7. Den_D 54 21.11.13 11:07 Сейчас в теме
Хорошо, доступно оформленная мысль. Автору спасибо. Для кого-то будет шпаркалкой.
10. Vladimir Litvinenko 2869 29.11.13 03:11 Сейчас в теме
Спасибо за публикацию. Использовал этот метод в http://infostart.ru/public/239307/
11. пользователь 03.01.14 11:50
Сообщение было скрыто модератором.
...
12. ysokolova 17.07.15 16:10 Сейчас в теме
Спасибо за статью! Но у меня почему-то пропадают значки документов в списке после указанных действий ((( Кто сталкивался с такой проблемой?
13. Mart 105 19.08.15 16:27 Сейчас в теме
(12) 7nightfly7, сложно диагностировать без скриншотика, картинки строк настраиваются в свойствах списка на закладке Использование (свойство ПутьКДаннымКартинкиСтроки обычно равно значению Список.СтандартнаяКартинка). Если же в списке использовалось свое собственное поле картинки, то нужно проследить, что реквизит списка, связанный с картинкой строк, присутствует в выбранных полях текста запроса.
14. andy23 467 28.09.16 09:40 Сейчас в теме
Столкнулся с тем, что при такой схеме не корректно работают отборы с условиями с НЕ (НЕ равно, НЕ в списке) для поля с табличной частью
15. HenrySLAV 03.10.17 16:45 Сейчас в теме
Просто
СГРУППИРОВАТЬ ПО
    ДокументТабельУчетаРабочегоВремени.Ссылка

тоже замечательно работает
16. rpgshnik 3631 07.10.19 08:51 Сейчас в теме
Чуть было не изобрел велосипед! Спасибо автору ⭐
17. German_Tagil 42 28.07.20 12:03 Сейчас в теме
метод работает но только после того как поставил различные и комментарий ужал
а так все красиво вот думаю попробовать ему список номенклатуры подсунуть
18. kras01 23.03.24 20:41 Сейчас в теме
Дополню тему, т.к. сам искал недавно. Можно сделать без изменения запроса и в одну строчку через БСП, пример ниже
ОбщегоНазначенияКлиентСервер.УстановитьЭлементОтбораДинамическогоСписка(Список, "Ссылка.Товары.Номенклатура", Номенклатура, ВидСравненияКомпоновкиДанных.Равно,, ЗначениеЗаполнено(Номенклатура));
Оставьте свое сообщение