gifts2017

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

Опубликовал Юрий (Mart) в раздел Программирование - Практика программирования

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

См. также

Подписаться Добавить вознаграждение
Комментарии
1. Armando Armando (Armando) 15.11.13 23:21
В запросе соединение надо в фигурные скобки заключить, иначе будете иметь соединение даже при отключенном отборе, что для динамических списков бывает болезненно. И вместо группировки лучше использовать "Различные". На производительность это скорее всего не повлияет, но смотрится лучше, и методически правильнее.
2. Юрий (Mart) 16.11.13 14:31
Да, согласен. Спасибо за замечание.
3. kiv82 (AltF1) 18.11.13 14:19
Вот оно, спасибо автору за раскрытие.
4. mxm2 mxm2 (mxm2) 20.11.13 08:37
Вроде как всегда хватало просто Ctrl + F на соответствующей табличной части и получим отбор по одному полю.
Ctrl + Q - отключение отбора.
5. Юрий (Mart) 20.11.13 12:57
(4) mxm2, Верно, эти комбинации клавиш действительно управляют отбором табличной части самого документа, но здесь речь про журнал(список) документов, в котором нужно управлять отбором по полям реквизитов табличных частей документа.
6. mxm2 mxm2 (mxm2) 20.11.13 13:39
(5) Mart, Каюсь... Не въехал сразу. )
7. Денис (Den_D) 21.11.13 11:07
Хорошо, доступно оформленная мысль. Автору спасибо. Для кого-то будет шпаркалкой.
8. Никита Грызлов (nixel) 21.11.13 14:56
(1) Armando, вопрос сравнения производительности и выбора конструкций distinct (различные) и group by довольно часто поднимается и однозначного ответа на него нет. Уж больно все разнится на разных субд и разных запросах :)
Да, "различные" проще и красивее выглядит, но не всегда быстрее :)
9. Armando Armando (Armando) 21.11.13 15:14
(8) nixel, я тоже точно не знаю. Надо план запроса смотреть. Просто привык, что вместе с группировкой используются агрегатные функции. А тут конкретно уникальные строки получить надо.
10. Владимир Литвиненко (VladimirL) 29.11.13 03:11
Спасибо за публикацию. Использовал этот метод в http://infostart.ru/public/239307/
12. Юлия Соколова (7nightfly7) 17.07.15 16:10
Спасибо за статью! Но у меня почему-то пропадают значки документов в списке после указанных действий ((( Кто сталкивался с такой проблемой?
13. Юрий (Mart) 19.08.15 16:27
(12) 7nightfly7, сложно диагностировать без скриншотика, картинки строк настраиваются в свойствах списка на закладке Использование (свойство ПутьКДаннымКартинкиСтроки обычно равно значению Список.СтандартнаяКартинка). Если же в списке использовалось свое собственное поле картинки, то нужно проследить, что реквизит списка, связанный с картинкой строк, присутствует в выбранных полях текста запроса.
14. Андрей Шабашов (andy23) 28.09.16 09:40
Столкнулся с тем, что при такой схеме не корректно работают отборы с условиями с НЕ (НЕ равно, НЕ в списке) для поля с табличной частью