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

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    177586    986    403    

943

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

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

2 стартмани

06.02.2025    1766    14    XilDen    26    

35

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

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

18.10.2024    12396    sergey279    18    

65

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

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

11.10.2024    7418    XilDen    36    

90

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

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

16.08.2024    10050    user1840182    5    

29

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

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

08.07.2024    3004    ivanov660    9    

22

Запросы СКД Программист Стажер Система компоновки данных Россия Бесплатно (free)

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

15.05.2024    11906    implecs    6    

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