Форма выбора по произвольному запросу в управляемых формах

16.02.21

Разработка - Запросы

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Форма выбора по произвольному запросу в управляемых формах.:
.epf 10,53Kb
10
10 Скачать (1 SM) Купить за 1 850 руб.

Данная обработка содержит форму "ФормаВыбораПоЗапросу",  которую в дальнейшем рекомендую перенести в Общие формы и использовать из конфигурации, и  форму с примером использования "Форма".  Из Формы ФормаВыбораПоЗапросу вызывается при выборе Договора, если необходимо сделать Выбор, или по кнопке "Список контрагентов", если достаточно отобразить форму с результатом Запроса.  ФормеВыбораПоЗапросу передается произвольный текст Запроса и необходимые ПараметрыЗапроса, указание на ТекущуюПозицию в полученом наборе данных и Заголовок формы.

         ПараметрыФормы = Новый Структура;
         ПараметрыФормы.Вставить("РежимВыбора", Истина);
         ПараметрыФормы.Вставить("ТекстЗапроса", ТекстЗапроса);
         ПараметрыФормы.Вставить("ПараметрыЗапроса", ПараметрыЗапроса);
         ПараметрыФормы.Вставить("ТекущаяПозиция", ТекущаяПозиция);
         ПараметрыФормы.Вставить("Заголовок", "Список договоров");

где

         ПараметрыЗапроса  - это структура, в которой ключ – имя параметра, а значение – это значение параметра. Например:

         ПараметрыЗапроса = Новый Структура;
         ПараметрыЗапроса.Вставить("Владелец", ТекущиеДанные.Контрагент);
         ПараметрыЗапроса.Вставить("Организация", Объект.Организация);

         ТекущаяПозиция – это структура, в которой ключ – имя поля, а значение – это значение поля. После открытия Формы выбора курсор будет установлен в строку, значение поля в которой будет совпадать с передаваемым.

Например:  

        ТекущаяПозиция = Новый Структура;
        ТекущаяПозиция.Вставить("Ссылка", ТекущиеДанные.ДоговорКонтрагента);

И наконец вызов Формы выбора из ВнешняяОбработки (или Конфигурации)

    

//ОткрытьФорму("ОбщаяФорма.ФормаВыбораПоЗапросу", ПараметрыФормы, ЭтаФорма,,,,Оп);
    ОткрытьФорму("ВнешняяОбработка.ВыборПоЗапросу.Форма.ФормаВыбораПоЗапросу", ПараметрыФормы, ЭтаФорма,,,,Оп);


 

Более наглядно можно увидеть из примера использования. Используйте данный пример как шаблон для разработки, указывая свой запрос и необходимые параметры.

//------ Пример использования Формы выбора по запросу  --------////

&НаКлиенте
Процедура ТаблицаДоговорНачалоВыбора(Элемент, ДанныеВыбора, СтандартнаяОбработка) 
	ТекущиеДанные = ЭтаФорма.Элементы.Состав.ТекущиеДанные;
	СтандартнаяОбработка = ложь;
	Если ТекущиеДанные = Неопределено тогда
		Возврат;
	КонецЕсли;
	
	ТекстЗапроса = "
		|ВЫБРАТЬ
		|	ДоговорыКонтрагентов.Ссылка КАК Ссылка,
		|	ДоговорыКонтрагентов.ВидДоговора КАК ВидДоговора,
		|	ДоговорыКонтрагентов.Дата КАК Дата,
		|	ДоговорыКонтрагентов.Номер КАК Номер,
		|	ДоговорыКонтрагентов.ВалютаВзаиморасчетов КАК ВалютаВзаиморасчетов
		|ИЗ
		|	Справочник.ДоговорыКонтрагентов КАК ДоговорыКонтрагентов
		|ГДЕ
		|	ДоговорыКонтрагентов.Владелец = &Владелец
		|	И ДоговорыКонтрагентов.Организация = &Организация
		|";
	
	ПараметрыЗапроса = Новый Структура;
	ПараметрыЗапроса.Вставить("Владелец", ТекущиеДанные[СтолбецКонтрагент]);
	ПараметрыЗапроса.Вставить("Организация", Объект.Организация);
	
	ТекущаяПозиция = Новый Структура;
	ТекущаяПозиция.Вставить("Ссылка", ТекущиеДанные[СтолбецДоговор]);
	
	ПараметрыФормы = Новый Структура;
	ПараметрыФормы.Вставить("РежимВыбора", Истина);
	ПараметрыФормы.Вставить("ТекстЗапроса", ТекстЗапроса);
	ПараметрыФормы.Вставить("ПараметрыЗапроса", ПараметрыЗапроса);
	ПараметрыФормы.Вставить("ТекущаяПозиция", ТекущаяПозиция);
	ПараметрыФормы.Вставить("Заголовок", "Список договоров");
	 
	Оп = Новый ОписаниеОповещения("ВыборДоговора", ЭтотОбъект, ТекущиеДанные);
	
	//ОткрытьФорму("ОбщаяФорма.ФормаВыбораПоЗапросу", ПараметрыФормы, ЭтаФорма,,,,Оп);
	ОткрытьФорму("ВнешняяОбработка.ВыборПоЗапросу.Форма.ФормаВыбораПоЗапросу", ПараметрыФормы, ЭтаФорма,,,,Оп);
	
КонецПроцедуры

&НаКлиенте
Процедура ВыборДоговора(РезультатВыбора, ТекущиеДанные) Экспорт
	
	Если РезультатВыбора <> Неопределено Тогда
		ТекущиеДанные[СтолбецДоговор] = РезультатВыбора.Ссылка;
	КонецЕсли;
	
КонецПроцедуры

//-------------------------------------------------------------////
 

Обработка тестировалась в  1С:Предприятие 8.3 (8.3.16.1063).

Форма выбор запрос Таблица Значений

См. также

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

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

15500 руб.

02.09.2020    184193    1024    403    

967

Обновление 1С Запросы Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

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

2 стартмани

06.02.2025    2174    17    XilDen    26    

36

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

В статье приведена удобная возможность отладки исполняемого запроса динамического списка.

03.12.2024    5679    artemusII    11    

23

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    13090    sergey279    18    

65

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    8179    XilDen    36    

90

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

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    3164    PROSTO-1C    0    

23

Запросы Программист Запросы Бесплатно (free)

Отлаживая взаимодействие с базой данных, мы регулярно сталкиваемся с зависающими или подозрительно долго выполняющимися обращениями, негативно влияющими на производительность. О том, как в PostgreSQL выявить подозрительные запросы, основываясь на доступной о них информации, расскажем в статье.

16.08.2024    10764    user1840182    5    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. NeLenin 14 01.04.21 09:57 Сейчас в теме
Лет 7 уже такую использую. В моих поделках она эволюционировала, можно и выбор делать, и подбор.
blockcode; +1 Ответить
Оставьте свое сообщение