Пример создания справочников через конструктор запросов 1с. Конструктор запросов схемы компоновки данных

Итак, начинаем с простого: в конфигураторе создайте Новую обработку,назовите КонсольЗапросов или КонструкторЗапросов,как Вам больше нравится.

Сразу можем добавить в “Данных” табличку для будущих Параметров, которые нам необходимы, чтобы в своей Консоли у нас выполнялся не самый примитивный запрос, а с параметрами и ссылками,например, мы для своей работы будем создавать запрос к периодическим регистрам, а здесь без указания Параметра=&Дата никуда.

Чтобы создать нашу табличку Параметров, на вкладке “Данные” в ее “Табличной части” добавим новую таблицу,назовем ее ПараметрыЗапроса, здесь же добавим колонки этой таблицы:1)ИмяПараметра,тип строка=25символов; ЗначениеПараметра, здесь составной тип данных см.рис:

Поэтому как показано на картинке – выбираем составной тип для колонки ЗначениеПараметра:в открывшемся меню типов ставим галочку “Составной тип”, выбираем число,строка (20символов укажите),дата,булево, и самую нижнюю галочку ставим – ЛюбаяСсылка – она означает что далее, при указании Параметров нашего запроса, мы можем ссылаться на любой объект нашей конфигурации,например,справочники или документы.

Теперь нужно создать форму нашей будущей Консоли запросов. В обработке перейдем на вкладку “Формы” и добавим новую.Входим в эту форму и здесь уже неограниченное поле для творчества – Вы можете расположить созданных только что два реквизита и табличку с параметрами как Вам больше нравится! Для этого Вы можете использовать стандартные элементы формы как Группа или Страница со страницами (если Вам больше нравится переворачивающиеся страницы.

Главное здесь одно: перетащив реквизит “ТекстЗначения” в левое поле редактирования формы – обязательно в его свойствах установите “Вид”=Поле текстового документа.см.рис:

В свойствах реквизита “ТаблицаЗапроса” по желанию можете указать – “ОтображатьСетку”и”ОтображатьЗаголовки”.

Далее в правом окне редактирования формы переходим на вкладку “Команды” и добавляем новую кнопку,при нажатии на которую наша Консоль выполнить определенное действие. Создадим Кнопку “КонструкторЗапросов”, по собственному желанию Вы можете на кнопку добавить пиктограммку, главное – это вынесите саму кнопку в левое окно редактирования формы – чтобы мы смогли ее увидеть.Потом в правом окне редактирования формы нажимаем правый клик мыши на нашу кнопку и выбираем свойства – в свойствах нажимаем на пункт “Действие”,появится модальное окно с вопросом – где именно будет исполняться наш программный код, который мы назначим кнопке – выбирайте “На клиенте”.

Откроется МодульФормы с уже готовой пустой процедурой “Процедура КонструкторЗапроса(Команда)”. Внутри данной процедуры мы и опишем вызов стандартного Конструктора запросов 1с8. Это очень легко: Конструктор=Новый КонструкторЗапроса; Но здесь есть подводные камни – встроенный в платформу КонстукторЗапросов работает в пользовательском режиме ТОЛЬКО под толстым клиентом! Поэтому мы вставим условие инструкции препроцессора #Если, а вот здесь Вы сами решайте, исходя из Вашей платформы, или у Вас обычные формы,тогда выбирайте “ТолстыйКлиентОбычноеПриложение ” или у Вас платформа на управляемых формах, тогда “ТолстыйКлиентУправляемоеПриложение “.см.рис.

Теперь осталось добавить в данную процедуру условие на запись текста запроса, который сформирует нам Конструктор запросов в наш реквизит формы “ТектЗапроса”:

Если Конструктор.ОткрытьМодально()=Истина Тогда Объект.ТекстЗапроса=Конструктор.Текст; КонецЕсли;

Но мы можем что-то вручную поменять в тексте запроса (в пользовательском режиме – в окне реквизита “ТекстЗапроса”), чтобы наши изменения попали в КонструкторЗапросов при его новом вызове – добавим простое условие здесь же:

Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли;

Все, мы подключили встроенный в платформу 1с8 КонструкторЗапросов, давайте посмотрим на свои труды. Для этого запустите 1С:Предприятие в режиме толстого клиента одним из указанных способов:1)гл.меню Конфигуратора – Отладка – НачалоОтладки – ТолстыйКлиент; 2) или если у Вас вынесены данные клавиши на панель управления в конфигураторе – просто нажмите кнопку с желтым кружком с толстой точкой см.рис.:

Запускается пользовательский режим 1сПредприятие8, находим нашу обработку, запускаем ее, жмем на нашу кнопку “КонструкторЗапросов” и видим, как открывается встроенный в платформу конструктор. см рис.

Итак, КонструкторЗапросов у нас запускается, можно уже в нем начинать складывать наш будущий запрос, но нам же интересно увидеть, как отработается созданный нами запрос! А для этого нам нужно создать в конфигураторе в редактировании формы нашей консоли еще одну кнопку, назовем ее “ВыполнитьЗапрос”. Нажимаем в свойствах кнопки “ВыполнитьЗапрос” на “Действие”, вновь выпадает меню, в котором нас спрашивают – где будет отрабатываться наш программный код, в данном случае выбираем “И на клиенте и на сервере”, вновь попадаем в МодульФормы.

В процедуре ВыполнитьЗапрос(), которая у нас на клиенте, запишим условие если пользователь не ввел текст запроса,а просит его выполнить:

Если ПустаяСтрока(Объект.ТекстЗапроса) Тогда сообщить("Введите текст запроса!"); КонецЕсли;

Система нам уже автоматически сформировала ссылку на процедуру ВыполнитьЗапросНаСервере(); – вот и хорошо, переходим в эту процедуру, которая исполняется на сервере и напишем здесь код исполнения нашего введенного запроса.

Здесь есть варианты: Вы можете самостоятельно писать все выражения, связанные с построением запросов,т.е. вручную, но есть еще проще вариант – внутри процедуры нажмите правую клавишу мыши и в выпадающем меню выберите пункт “Конструктор запросов с обработкой результатов см.рис.”:

Если Вы нажали на пункт Конструктор запросов с обработкой результатов”, то выпадет модальное окно “Не найден текст запроса.Создать новый?”,нажимайте да.Откроется встроенный конструктор запроса, в котором на его первой вкладке “Обработка результата” – выбираем пункт первый “Обход результата”. Все, больше нам от этого конструктора ничего не нужно, нажимаем на кнопку “Ок” – выпадет модальное окно “В запросе не выбрано ни одного поля, жмем “Ок”.

После этого внутри нашей процедуры ВыполнитьЗапросНаСервере() появится вот такая готовая заготовочка:

Перейдем к построенному конструктором выражению:

Запрос.Текст = "";

Запрос.Текст =Объект.ТекстЗапроса;

Вот так все просто, наша кнопка “ВыполнитьЗапрос” на форме обработки уже практически работоспособна, пока что она может обрабатывать только простые запросы без параметров, но главное что работает! Осталось только вывести визуально в реквизит “ТаблицаЗначений” на форме обработки – результаты нашего запроса. Напомню,что наш реквизит “ТаблицаЗначений” имеет тип “Табличный документ”, потому что иначе никак мы в пользовательском режиме не увидим наши результаты. Выводом табличных данных пользователю всегда занимается или Табличный документ или Макет, мне бы очень хотелось чтобы можно было вывести данные через таблицу значений – так как она очень простая в работе и привычная, но, к сожалению, таблица значений – это лишь инструмент, который нужен разработчику, выдавать данные на экран с помощью нее нельзя…

Рассмотрим подробней, что такое есть Табличный Документ-это как лист Exel – добраться до записи в конкретную ячейку можно только с помощью Ячеек таблицы, здесь они у нас называются область, но мы сами можем выбрать диапазон этой области в одну конкретную Ячейку:

Итак, разобрались, что такое табличный документ, определили для себя, что нам потребуется в конкретную ячейку данного табличного документа определить данные из нашего запроса. Но подумаем: а что такое “РезультатЗапроса”, который конструктор нам так быстро сформировал? Открываем справку – Результат запроса – это таблица, у которой есть соответствующие свойства! см.рис.

И если мы сейчас напишем после выражения РезультатЗапроса = Запрос.Выполнить();(созданного конструктором) вот такой простой цикл для Коллекций:

Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл сообщить(ИмяКолонки.Имя); КонецЦикла;

После этого цикла пока что заремарьте все выражения построенные автоматически конструктором. И запустите 1С:Предприятие8 под толстым клиентом.Создайте любой простенький запрос (Можно Конструктором запросов – он у нас уже работает) и нажмите на кнопку “ВыполнитьЗапрос”:

То Вы увидите внизу окна в сообщения – что в таблице РезультатЗапроса хранятся наименование полей, которые мы только что выбрали, создав простенький запрос.

Теперь выведем эти имена полей наших страданий в Табличный документ:

Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл Ячейка=Объект.ТаблицаЗапроса.Область(1,РезультатЗапроса.Колонки.Индекс(ИмяКолонки)+1); Ячейка.Текст=ИмяКолонки.Имя; КонецЦикла;

Чтобы вывести деталировку по данным запроса – разремарим созданные автоматически конструктором выражения и внутрь цикла перебора “ВыборкаДетальныеЗаписи” самого запроса вставим точно такой же цикл,который мы использовали для вывода наименований колонок, только теперь в текст Ячейки нам нужно передать не данные таблицы”РезультатЗапроса”, а данные самой Выборки, посмотрим в справке, как можно обратиться к полю Детальной выборки запроса:

ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); Пока ВыборкаДетальныеЗаписи.Следующий() Цикл //в первой строке у нас уже записаны имена колонок таблицы,поэтому данные загружаем ниже первой строки НомерСтрокиДок=Объект.ТаблицаЗапроса.ВысотаТаблицы+1; Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл Ячейка=Объект.ТаблицаЗапроса.Область(НомерСтрокиДок,РезультатЗапроса.Колонки.Индекс(ИмяКолонки)+1); Ячейка.Текст=ВыборкаДетальныеЗаписи[ИмяКолонки.Имя]; КонецЦикла; КонецЦикла;

Все, можем проверять, загружаем предприятие под толстым клиентом, вводим простой запрос без параметров, нажимаем на кнопку “ВыполнитьЗапрос” см.рис:

Ура, все работает!!!

Очень удобно, когда при открытии/закрытии нашей Консоли запросов – вновь в поле “ТекстЗапроса” записывается наш текст запроса, с которым мы перед закрытием консоли работали. Для этого просто нужно включить свойство формы = Автосохранение см.рис:

Все, наша консоль работает. Чтобы мы могли писать более сложные запросы с указанием в них параметров – нужно создать еще одну кнопку “НайтиПараметры”, так же как и код кнопки “ВыполнитьЗапрос” – код кнопки “НайтиПараметры” будет выполняться на клиенте и на сервере. Далее в серверной процедуре мы точно так же запускаем запрос с переданным в него текстом из окна “ТекстЗапроса”, с помощью выражения “Запрос.НайтиПараметры()” находим переданные параметры и просто в цикле вносим их в табличную часть формы “ПараметрыЗапроса”. Не забудьте потом из заполненной таблицы параметров передать их в процедуру “ВыполнитьЗапрос”.

Можно еще к нашей Консоли добавить пару кнопок, которые будут очищать в пользовательском режиме окно Параметров и окно Текста запроса.

Наша Консоль запросов готова к использованию, желаю успешных творческих решений с помощью такого простого и мощного инструмента, как Консоль запросов!

Данная обработка написана на платформе 1с8.3 (управляемые формы), запускается под толстым клиентом. Так же ее можно написать и на платформе 1с8.2 как под обычными формами, так и под управляемыми.

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

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

Апгрейд Консоли Запросов:

1)Теперь наша самодельная Консоль запросов со встроенным Конструктором запросов будет запускаться под любым клиентом: под толстым клиентом обычных и управляемых форм и под тонким и веб клиентом.

п.с.Форма и вид встроенного Конструктора запроса отличается – в зависимости от того под каким клиентом мы запустили нашу Консоль.(лично мне привычней и удобней форма Конструктора запросов под толстым клиентом)

&НаКлиенте Процедура КонструкторЗапроса(Команда) //вызов стандартного Конструктора запроса возможен только под толстым клиентом #Если ТолстыйКлиентУправляемоеПриложение или ТолстыйКлиентОбычноеПриложение Тогда Конструктор=Новый КонструкторЗапроса; Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли; Если Конструктор.ОткрытьМодально()=Истина Тогда Объект.ТекстЗапроса=Конструктор.Текст; КонецЕсли; // #Иначе // Сообщить("Вызов Конструктора запросов возможен только под толстым клиентом"); // Возврат; //# КонецЕсли #Иначе Сообщить("Вы запускаете Конструктор запросов под тонким клиентом - он отличается немного по своей форме и скорости производительности!"); Конструктор = Новый КонструкторЗапроса(); Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли; ОповещениеКонструктора = Новый ОписаниеОповещения("ВыполнитьПослеЗакрытияКонструктора", ЭтаФорма); Конструктор.Показать(ОповещениеКонструктора); # КонецЕсли КонецПроцедуры &НаКлиенте Процедура ВыполнитьПослеЗакрытияКонструктора(Результат, ПараметрыКонструктора) Экспорт //Результат=текст,если Конс-р закрыли по кнопке ок Объект.ТекстЗапроса = СокрЛП(Результат); //работает!!! КонецПроцедуры

2)Добавила возможность в нашу простую Консоль запросов вводить сложные запросы с передаваемой в параметры Временной таблицей!!! Механизм получился очень простой и элегантный – без использования XML-кода, как делают в профессиональных консолях.

Сам код и процедуры по механизму передачи в параметры Временных таблиц Вы сможете посмотреть во втором прикрепленном файле. С чего начала разрабатывать свой вариант Временных таблиц в параметрах можно посмотреть по этой ссылке https://forum.infostart.ru/forum9/topic183700/

Теперь как пользоваться Консолью при сложном запросе, когда в его параметры передана временная таблица. Для примера можете взять код вот этого запроса;

ВЫБРАТЬ ВнешниеДанные.Товар, ВнешниеДанные.Количество ПОМЕСТИТЬ ВнешниеДанные ИЗ &ВнешниеДанные КАК ВнешниеДанные; //////////////////////////////////////////////////////////////////////////////// ВЫБРАТЬ ВнешниеДанные.Товар, ВнешниеДанные.Количество, ЕСТЬNULL(ОстаткиТоваровОстатки.КоличествоОстаток, 0) КАК Поле1, ЕСТЬNULL(ОстаткиТоваровОстатки.КоличествоОстаток, 0) - ВнешниеДанные.Количество КАК Осталось ИЗ ВнешниеДанные КАК ВнешниеДанные ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ОстаткиТоваров.Остатки(&Дата, Товар В (ВЫБРАТЬ ВнешниеДанные.Товар ИЗ ВнешниеДанные КАК ВнешниеДанные)) КАК ОстаткиТоваровОстатки ПО ВнешниеДанные.Товар = ОстаткиТоваровОстатки.Товар

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

Итак, в конструкторе запросов мы создали выше приведенный запрос,закрыв Конструктор – текст запроса попадет в наше поле консоли “ТекстЗапроса”,нажимаем на кнопку “НайтиПараметры”, видим, что в таблице Параметров появилась строка = “ВнешниеДанные”,типЗначения=”ТаблицаЗначения”,см.рис.

В данной таблице Параметров – вводим параметр Дата,н-р, сегодняшняя дата, потом нажимаем для попытки редактирования на наш параметр временной таблицы “ВнешниеДанные”, нажимаем в поле с “ТаблицаЗначений” на три точки – появится выбор типов,жмем строка, наш механизм переворачивает нам страницу на форме, где нам необходимо в ручную ввести эту самую временную таблицу.

Здесь отметьте, что при этом на странице “ВремТаблицы” внизу в поле “Имя временной таблицы в параметрах” – появится имя нашей временной таблицы (оно копируется с таблицы Параметров).

Пока что на странице “ВремТаблицы” мы види только одну пустую таблицу – это таблица Типов нашей будущей временной таблицы.С помощью кнопки “Добавить” – добавим наименование реквизита и типа будущей таблицы. Будьте внимательны – наименование и тип должен соответствовать тому, что мы задали в запросе для &ВнешниеДанные:

Теперь нажимаем кнопку “ОбновитьВременнуюТаблицу” – и у нас здесь же появится вторая таблица – в нее мы уже непосредственно будем набивать через кнопку “Добавить” данные временной таблицы.

Все,можем еще раз перепроверить себя ввели ли мы примитивные данные параметров запроса в таблице параметров на 1-й странице обработки, и жмем кнопку “ВыполнитьЗапрос” – все считает,выбирает соответственно с ограничением по данным, переданых в параметре нашей временной таблицы

п.с.Если Вы сделали ошибку при наборе наименования реквизитов и их типов (в первой таблице) – просто закройте Консоль и откройте ее вновь – временная таблица данных будет стерта – и таблицу Типов вновь можно отредактировать и создать вновь новую таблицу данных.

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

Вот и все, мы можем своими руками создать очень мощный рабочий инструмент, кроме того, наша консоль еще очень шустрая по сравнению с профессиональными – а это очень большой плюс для разработчиков! И,конечно, теперь наша консоль работает под любым клиентом! Удачи в Ваших творческих разработках!!!

Итак, начинаем с простого: в конфигураторе создайте Новую обработку,назовите КонсольЗапросов или КонструкторЗапросов,как Вам больше нравится.

Сразу можем добавить в "Данных" табличку для будущих Параметров, которые нам необходимы, чтобы в своей Консоли у нас выполнялся не самый примитивный запрос, а с параметрами и ссылками,например, мы для своей работы будем создавать запрос к периодическим регистрам, а здесь без указания Параметра=&Дата никуда.

Чтобы создать нашу табличку Параметров, на вкладке "Данные" в ее "Табличной части" добавим новую таблицу,назовем ее ПараметрыЗапроса, здесь же добавим колонки этой таблицы:1)ИмяПараметра,тип строка=25символов; ЗначениеПараметра, здесь составной тип данных см.рис:

Поэтому как показано на картинке - выбираем составной тип для колонки ЗначениеПараметра:в открывшемся меню типов ставим галочку "Составной тип", выбираем число,строка (20символов укажите),дата,булево, и самую нижнюю галочку ставим - ЛюбаяСсылка - она означает что далее, при указании Параметров нашего запроса, мы можем ссылаться на любой объект нашей конфигурации,например,справочники или документы.

Теперь нужно создать форму нашей будущей Консоли запросов. В обработке перейдем на вкладку "Формы" и добавим новую.Входим в эту форму и здесь уже неограниченное поле для творчества - Вы можете расположить созданных только что два реквизита и табличку с параметрами как Вам больше нравится! Для этого Вы можете использовать стандартные элементы формы как Группа или Страница со страницами (если Вам больше нравится переворачивающиеся страницы.

Главное здесь одно: перетащив реквизит "ТекстЗначения" в левое поле редактирования формы - обязательно в его свойствах установите "Вид"=Поле текстового документа.см.рис:

В свойствах реквизита "ТаблицаЗапроса" по желанию можете указать - "ОтображатьСетку"и"ОтображатьЗаголовки".

Далее в правом окне редактирования формы переходим на вкладку "Команды" и добавляем новую кнопку,при нажатии на которую наша Консоль выполнить определенное действие. Создадим Кнопку "КонструкторЗапросов", по собственному желанию Вы можете на кнопку добавить пиктограммку, главное - это вынесите саму кнопку в левое окно редактирования формы - чтобы мы смогли ее увидеть.Потом в правом окне редактирования формы нажимаем правый клик мыши на нашу кнопку и выбираем свойства - в свойствах нажимаем на пункт "Действие",появится модальное окно с вопросом - где именно будет исполняться наш программный код, который мы назначим кнопке - выбирайте "На клиенте".

Откроется МодульФормы с уже готовой пустой процедурой "Процедура КонструкторЗапроса(Команда)". Внутри данной процедуры мы и опишем вызов стандартного Конструктора запросов 1с8. Это очень легко: Конструктор=Новый КонструкторЗапроса; Но здесь есть подводные камни - встроенный в платформу КонстукторЗапросов работает в пользовательском режиме ТОЛЬКО под толстым клиентом! Поэтому мы вставим условие инструкции препроцессора #Если, а вот здесь Вы сами решайте, исходя из Вашей платформы, или у Вас обычные формы,тогда выбирайте "ТолстыйКлиентОбычноеПриложение " или у Вас платформа на управляемых формах, тогда "ТолстыйКлиентУправляемоеПриложение ".см.рис.

Теперь осталось добавить в данную процедуру условие на запись текста запроса, который сформирует нам Конструктор запросов в наш реквизит формы "ТектЗапроса":

Если Конструктор.ОткрытьМодально()=Истина Тогда Объект.ТекстЗапроса=Конструктор.Текст; КонецЕсли;

Но мы можем что-то вручную поменять в тексте запроса (в пользовательском режиме - в окне реквизита "ТекстЗапроса"), чтобы наши изменения попали в КонструкторЗапросов при его новом вызове - добавим простое условие здесь же:

Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли;

Все, мы подключили встроенный в платформу 1с8 КонструкторЗапросов, давайте посмотрим на свои труды. Для этого запустите 1С:Предприятие в режиме толстого клиента одним из указанных способов:1)гл.меню Конфигуратора - Отладка - НачалоОтладки - ТолстыйКлиент; 2) или если у Вас вынесены данные клавиши на панель управления в конфигураторе - просто нажмите кнопку с желтым кружком с толстой точкой см.рис.:

Запускается пользовательский режим 1сПредприятие8, находим нашу обработку, запускаем ее, жмем на нашу кнопку "КонструкторЗапросов" и видим, как открывается встроенный в платформу конструктор. см рис.

Итак, КонструкторЗапросов у нас запускается, можно уже в нем начинать складывать наш будущий запрос, но нам же интересно увидеть, как отработается созданный нами запрос! А для этого нам нужно создать в конфигураторе в редактировании формы нашей консоли еще одну кнопку, назовем ее "ВыполнитьЗапрос". Нажимаем в свойствах кнопки "ВыполнитьЗапрос" на "Действие", вновь выпадает меню, в котором нас спрашивают - где будет отрабатываться наш программный код, в данном случае выбираем "И на клиенте и на сервере", вновь попадаем в МодульФормы.

В процедуре ВыполнитьЗапрос(), которая у нас на клиенте, запишим условие если пользователь не ввел текст запроса,а просит его выполнить:

Если ПустаяСтрока(Объект.ТекстЗапроса) Тогда сообщить("Введите текст запроса!"); КонецЕсли;

Система нам уже автоматически сформировала ссылку на процедуру ВыполнитьЗапросНаСервере(); - вот и хорошо, переходим в эту процедуру, которая исполняется на сервере и напишем здесь код исполнения нашего введенного запроса.

Здесь есть варианты: Вы можете самостоятельно писать все выражения, связанные с построением запросов,т.е. вручную, но есть еще проще вариант - внутри процедуры нажмите правую клавишу мыши и в выпадающем меню выберите пункт "Конструктор запросов с обработкой результатов см.рис.":

Если Вы нажали на пункт Конструктор запросов с обработкой результатов", то выпадет модальное окно "Не найден текст запроса.Создать новый?",нажимайте да.Откроется встроенный конструктор запроса, в котором на его первой вкладке "Обработка результата" - выбираем пункт первый "Обход результата". Все, больше нам от этого конструктора ничего не нужно, нажимаем на кнопку "Ок" - выпадет модальное окно "В запросе не выбрано ни одного поля, жмем "Ок".

После этого внутри нашей процедуры ВыполнитьЗапросНаСервере() появится вот такая готовая заготовочка:

Перейдем к построенному конструктором выражению:

Запрос.Текст = "";

Запрос.Текст =Объект.ТекстЗапроса;

Вот так все просто, наша кнопка "ВыполнитьЗапрос" на форме обработки уже практически работоспособна, пока что она может обрабатывать только простые запросы без параметров, но главное что работает! Осталось только вывести визуально в реквизит "ТаблицаЗначений" на форме обработки - результаты нашего запроса. Напомню,что наш реквизит "ТаблицаЗначений" имеет тип "Табличный документ", потому что иначе никак мы в пользовательском режиме не увидим наши результаты. Выводом табличных данных пользователю всегда занимается или Табличный документ или Макет, мне бы очень хотелось чтобы можно было вывести данные через таблицу значений - так как она очень простая в работе и привычная, но, к сожалению, таблица значений - это лишь инструмент, который нужен разработчику, выдавать данные на экран с помощью нее нельзя...

Рассмотрим подробней, что такое есть Табличный Документ-это как лист Exel - добраться до записи в конкретную ячейку можно только с помощью Ячеек таблицы, здесь они у нас называются область, но мы сами можем выбрать диапазон этой области в одну конкретную Ячейку:

Итак, разобрались, что такое табличный документ, определили для себя, что нам потребуется в конкретную ячейку данного табличного документа определить данные из нашего запроса. Но подумаем: а что такое "РезультатЗапроса", который конструктор нам так быстро сформировал? Открываем справку - Результат запроса - это таблица, у которой есть соответствующие свойства! см.рис.

И если мы сейчас напишем после выражения РезультатЗапроса = Запрос.Выполнить();(созданного конструктором) вот такой простой цикл для Коллекций:

Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл сообщить(ИмяКолонки.Имя); КонецЦикла;

После этого цикла пока что заремарьте все выражения построенные автоматически конструктором. И запустите 1С:Предприятие8 под толстым клиентом.Создайте любой простенький запрос (Можно Конструктором запросов - он у нас уже работает) и нажмите на кнопку "ВыполнитьЗапрос":

То Вы увидите внизу окна в сообщения - что в таблице РезультатЗапроса хранятся наименование полей, которые мы только что выбрали, создав простенький запрос.

Теперь выведем эти имена полей наших страданий в Табличный документ:

Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл Ячейка=Объект.ТаблицаЗапроса.Область(1,РезультатЗапроса.Колонки.Индекс(ИмяКолонки)+1); Ячейка.Текст=ИмяКолонки.Имя; КонецЦикла;

Чтобы вывести деталировку по данным запроса - разремарим созданные автоматически конструктором выражения и внутрь цикла перебора "ВыборкаДетальныеЗаписи" самого запроса вставим точно такой же цикл,который мы использовали для вывода наименований колонок, только теперь в текст Ячейки нам нужно передать не данные таблицы"РезультатЗапроса", а данные самой Выборки, посмотрим в справке, как можно обратиться к полю Детальной выборки запроса:

ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); Пока ВыборкаДетальныеЗаписи.Следующий() Цикл //в первой строке у нас уже записаны имена колонок таблицы,поэтому данные загружаем ниже первой строки НомерСтрокиДок=Объект.ТаблицаЗапроса.ВысотаТаблицы+1; Для каждого ИмяКолонки Из РезультатЗапроса.Колонки Цикл Ячейка=Объект.ТаблицаЗапроса.Область(НомерСтрокиДок,РезультатЗапроса.Колонки.Индекс(ИмяКолонки)+1); Ячейка.Текст=ВыборкаДетальныеЗаписи[ИмяКолонки.Имя]; КонецЦикла; КонецЦикла;

Все, можем проверять, загружаем предприятие под толстым клиентом, вводим простой запрос без параметров, нажимаем на кнопку "ВыполнитьЗапрос" см.рис:

Ура, все работает!!!

Очень удобно, когда при открытии/закрытии нашей Консоли запросов - вновь в поле "ТекстЗапроса" записывается наш текст запроса, с которым мы перед закрытием консоли работали. Для этого просто нужно включить свойство формы = Автосохранение см.рис:

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

Можно еще к нашей Консоли добавить пару кнопок, которые будут очищать в пользовательском режиме окно Параметров и окно Текста запроса.

Наша Консоль запросов готова к использованию, желаю успешных творческих решений с помощью такого простого и мощного инструмента, как Консоль запросов!

Данная обработка написана на платформе 1с8.3 (управляемые формы), запускается под толстым клиентом. Так же ее можно написать и на платформе 1с8.2 как под обычными формами, так и под управляемыми.

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

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

Апгрейд Консоли Запросов:

1)Теперь наша самодельная Консоль запросов со встроенным Конструктором запросов будет запускаться под любым клиентом: под толстым клиентом обычных и управляемых форм и под тонким и веб клиентом.

п.с.Форма и вид встроенного Конструктора запроса отличается - в зависимости от того под каким клиентом мы запустили нашу Консоль.(лично мне привычней и удобней форма Конструктора запросов под толстым клиентом)

&НаКлиенте Процедура КонструкторЗапроса(Команда) //вызов стандартного Конструктора запроса возможен только под толстым клиентом #Если ТолстыйКлиентУправляемоеПриложение или ТолстыйКлиентОбычноеПриложение Тогда Конструктор=Новый КонструкторЗапроса; Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли; Если Конструктор.ОткрытьМодально()=Истина Тогда Объект.ТекстЗапроса=Конструктор.Текст; КонецЕсли; // #Иначе // Сообщить("Вызов Конструктора запросов возможен только под толстым клиентом"); // Возврат; //# КонецЕсли #Иначе Сообщить("Вы запускаете Конструктор запросов под тонким клиентом - он отличается немного по своей форме и скорости производительности!"); Конструктор = Новый КонструкторЗапроса(); Если не ПустаяСтрока(Объект.ТекстЗапроса) Тогда Конструктор.Текст=Объект.ТекстЗапроса; КонецЕсли; ОповещениеКонструктора = Новый ОписаниеОповещения("ВыполнитьПослеЗакрытияКонструктора", ЭтаФорма); Конструктор.Показать(ОповещениеКонструктора); # КонецЕсли КонецПроцедуры &НаКлиенте Процедура ВыполнитьПослеЗакрытияКонструктора(Результат, ПараметрыКонструктора) Экспорт //Результат=текст,если Конс-р закрыли по кнопке ок Объект.ТекстЗапроса = СокрЛП(Результат); //работает!!! КонецПроцедуры

2)Добавила возможность в нашу простую Консоль запросов вводить сложные запросы с передаваемой в параметры Временной таблицей!!! Механизм получился очень простой и элегантный - без использования XML-кода, как делают в профессиональных консолях.

Сам код и процедуры по механизму передачи в параметры Временных таблиц Вы сможете посмотреть во втором прикрепленном файле. С чего начала разрабатывать свой вариант Временных таблиц в параметрах можно посмотреть по этой ссылке https://forum.сайт/forum9/topic183700/

Теперь как пользоваться Консолью при сложном запросе, когда в его параметры передана временная таблица. Для примера можете взять код вот этого запроса;

ВЫБРАТЬ ВнешниеДанные.Товар, ВнешниеДанные.Количество ПОМЕСТИТЬ ВнешниеДанные ИЗ &ВнешниеДанные КАК ВнешниеДанные; //////////////////////////////////////////////////////////////////////////////// ВЫБРАТЬ ВнешниеДанные.Товар, ВнешниеДанные.Количество, ЕСТЬNULL(ОстаткиТоваровОстатки.КоличествоОстаток, 0) КАК Поле1, ЕСТЬNULL(ОстаткиТоваровОстатки.КоличествоОстаток, 0) - ВнешниеДанные.Количество КАК Осталось ИЗ ВнешниеДанные КАК ВнешниеДанные ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ОстаткиТоваров.Остатки(&Дата, Товар В (ВЫБРАТЬ ВнешниеДанные.Товар ИЗ ВнешниеДанные КАК ВнешниеДанные)) КАК ОстаткиТоваровОстатки ПО ВнешниеДанные.Товар = ОстаткиТоваровОстатки.Товар

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

Итак, в конструкторе запросов мы создали выше приведенный запрос,закрыв Конструктор - текст запроса попадет в наше поле консоли "ТекстЗапроса",нажимаем на кнопку "НайтиПараметры", видим, что в таблице Параметров появилась строка = "ВнешниеДанные",типЗначения="ТаблицаЗначения",см.рис.

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

Здесь отметьте, что при этом на странице "ВремТаблицы" внизу в поле "Имя временной таблицы в параметрах" - появится имя нашей временной таблицы (оно копируется с таблицы Параметров).

Пока что на странице "ВремТаблицы" мы види только одну пустую таблицу - это таблица Типов нашей будущей временной таблицы.С помощью кнопки "Добавить" - добавим наименование реквизита и типа будущей таблицы. Будьте внимательны - наименование и тип должен соответствовать тому, что мы задали в запросе для &ВнешниеДанные:

Теперь нажимаем кнопку "ОбновитьВременнуюТаблицу" - и у нас здесь же появится вторая таблица - в нее мы уже непосредственно будем набивать через кнопку "Добавить" данные временной таблицы.

Все,можем еще раз перепроверить себя ввели ли мы примитивные данные параметров запроса в таблице параметров на 1-й странице обработки, и жмем кнопку "ВыполнитьЗапрос" - все считает,выбирает соответственно с ограничением по данным, переданых в параметре нашей временной таблицы

п.с.Если Вы сделали ошибку при наборе наименования реквизитов и их типов (в первой таблице) - просто закройте Консоль и откройте ее вновь - временная таблица данных будет стерта - и таблицу Типов вновь можно отредактировать и создать вновь новую таблицу данных.

Вот и все, мы можем своими руками создать очень мощный рабочий инструмент, кроме того, наша консоль еще очень шустрая по сравнению с профессиональными - а это очень большой плюс для разработчиков! И,конечно, теперь наша консоль работает под любым клиентом! Удачи в Ваших творческих разработках!!!

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

Работаю постоянно своей КонсольюЗапросов, и вот попался недавно очень интересный запрос, в котором Временные таблицы находились не в первом пакете запроса,а в следующих - и вот тут моя консолька чуточку захандрила...Пришлось ей делать еще один апгрейд.

Итак, менеждер Временных таблиц в запросе не всегда понимает, что с ним работают)) Поэтому нужно явно задать этот самый менеджер Временных таблиц:

&НаСервере Процедура ВыполнитьЗапросНаСервере() //апгрейд2-явное определение менеджера ВременныхТаблиц! МенеджерВТ=Новый МенеджерВременныхТаблиц; Запрос = Новый Запрос; //апгрейд2-явное определение менеджера ВременныхТаблиц! Запрос.МенеджерВременныхТаблиц = МенеджерВТ; Запрос.Текст = Объект.ТекстЗапроса;

Данный вариант консоли лежит в третьей загрузке.

Конструктор запросов в 1С 8.3 и 8.2 — мощнейший инструмент разработки. Он позволяет составить текст запроса при помощи специальной визуальной среды. Таким образом, чтобы создать запрос 1с не обязательно знать встроенный язык запросов, достаточно ориентироваться в не сложном и интуитивно понятном интерфейсе конструктора.

Конструктор запросов представляет из себя набор вкладок, каждая из которых отвечает за свою часть запроса. Так заполняя вкладку Таблицы и поля мы выбираем таблицы из которых запрос 1с будет получать данные и поля этих таблиц необходимые для решения конкретной задачи. Заполняя в кладку Условия мы накладываем условия на выбранные таблицы, для того чтобы выбрать из них только нужные нам данные и так далее.

Описание конструктора запросов на официальном сайте 1С 8: v8.1c.ru

Таблицы и поля; ; ; ; ; ; Вложенные запросы (в разработке).

Для того чтобы вызвать конструктор запросов 1с 8 в программном коде необходимо:

  • Создать новый запрос
Запрос = Новый Запрос;
  • Задать пустую строку текста запроса
Запрос.Текст = "";
  • Поставить курсор мышки между кавычками, нажать правую кнопку мыши. В открывшемся контекстном меню выбрать пункт Конструктор запроса и ответить Да на вопрос о создании нового запроса. Если текст запроса уже записан, то необходимо щелкнуть на любом месте внутри него и вызвать конструктор;

Рассмотрим на небольших примерах с возрастающей сложностью все основные вкладки конструктора запросов. Такой подход позволит начинающему программисту 1с более эффективно изучить конструктор и все его возможности. Для примеров будем использовать конфигурацию Бухгалтерия 3.0.

Урок №1. Конструктор запросов — простейший пример использования.

Задача: написать запрос к справочнику номенклатура, выбрать всю номенклатуру справочника.

Новые вкладки: Таблицы и поля.

Новые механизмы: просмотр и редактирование текста запроса при помощи кнопки «Запрос».

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

Теоретическая часть урока №1

Вкладка Таблицы и поля состоит из трех разделов:

База данных . В данном разделе представлены все таблицы базы данных, которые можно использовать для построения запроса;

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

  • Либо дважды щелкнуть по таблице;
  • Либо воспользоваться кнопками «>» или «>>».

Над разделом Таблицы присутствует ряд кнопок. Про большинство из них будет подробнее рассказано в следующих уроках. А пока дам только краткие пояснения.

  • Создать вложенный запрос (красная линия). Предназначена для создания нового вложенного запроса;
  • Создать описание временной таблицы (желтая линия). Позволяет задать имя временной таблицы, которая расположена вне данного запроса, также можно использовать для передачи в запрос таблицы значений;
  • Изменить текущий элемент (зеленая линия). Позволяет перейти в выделенный вложенный запрос, временную таблицу или описание временной таблицы;
  • Удалить текущий элемент (голубая линия). Удаляет выделенную таблицу из выбранных таблиц;
  • Заменить таблицу (синяя линия). Открывает диалог замены выделенной таблицы. Полезно, если вы неверно выбрали виртуальную таблицу регистра, так как происходит позиционирование на текущей выбранной таблице в списке.
  • Параметры виртуальной таблицы (фиолетовая линия). Открывает параметры виртуальной таблицы регистра.

Поля . В данный раздел выбираются поля таблиц из предыдущего раздела. Эти поля будут колонками таблицы или выборки полученной в результате выполнения запроса. Нужны они прежде всего, для того чтобы получить из выбранных таблиц только нужную в конкретном случае информацию. Для того чтобы переместить их из раздела Таблицы необходимо:

  • Либо дважды щелкнуть по полю;
  • Либо воспользоваться кнопками «>» или «>>»;
  • Также можно добавить новое поле самостоятельно, используя произвольное выражение из полей выбранных таблиц и функций языка запросов.

Над разделом Поля присутствует ряд кнопок. Про создание полей при помощи произвольных выражений будет подробнее рассказано в следующих уроках. А пока дам только краткие пояснения.

  • Добавить (зеленая линия). Предназначена для добавления нового поля при помощи редактора произвольных выражений;
  • Изменить текущий элемент (красная линия). Позволяет изменить выделенное поле при помощи редактора;
  • Удалить текущий (синяя линия). Удаляет выделенное поле из списка.

Практическая часть урока №1

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

Приступим к созданию запроса по номенклатуре:

  • Создадим новый запрос и откроем конструктор методом указанным в начале урока;
  • В разделе База данных , откроем ветку Справочники и найдем там справочник Номенклатура;
  • Выделим его и при помощи кнопки «>» перенесем в раздел Таблицы;
  • В разделе Таблицы раскроем справочник номенклатура при помощи значка «+»;
  • В раскрывшемся списке полей найдем поле Ссылка и перенесем его в раздел Поля при помощи кнопки «>»
  • Запрос по номенклатуре готов, нажимаем кнопку «ОК» в нижней части окна конструктора.

Сегодня поговорим о том как делать вложенные запросы с использованием конструктора запросов . Перейдем сразу к примеру.

Допустим у нас есть вот такой простейший регистр сведений, где хранятся цены в разрезе товаров и поставщиков:

Мы хотим запросом получить все товары у которых количество поставщиков больше одного. Это можно реализовать с помощью вот такого запроса:

ВЫБРАТЬ КоличествоПоставщиков.Товар КАК Товар ИЗ (ВЫБРАТЬ Цена.Товар КАК Товар, КОЛИЧЕСТВО(РАЗЛИЧНЫЕ Цена.Поставщик) КАК Поставщики ИЗ РегистрСведений.Цена КАК Цена СГРУППИРОВАТЬ ПО Цена.Товар) КАК КоличествоПоставщиков ГДЕ КоличествоПоставщиков.Поставщики > 1

Формируем вложенный запрос в конструкторе

Сформируем вышеприведенный запрос с помощью конструктора.

Для этого в командной панели над полем Таблицы нажимаем кнопку Создать вложенный запрос :


После чего у нас откроется окно с еще одним экземпляром конструктора запросов:


И в этом новом окне конструируем вложенный запрос:




Нажав на кнопку Запрос в нижнем левом углу мы можем посмотреть текст вложенного запроса:


После нажатия на кнопку ОК во вспомогательном конструкторе, получаем в основном окне следующую картину:


Поскольку словосочетание ВложенныйЗапрос не очень удобно для восприятия, давайте с помощью клика правой кнопкой мыши переименуем таблицу в КоличествоПоставщиков , выберем из нее поле Товар и на закладке Условия пропишем нужное условие:




И после всех этих манипуляций мы и получаем нужный запрос. При необходимости можно создавать запросы с несколькими уровнями вложенности.

Как из обычного запроса сделать вложенный в конструкторе

Очень часто возникает ситуация, когда начинаешь делать запрос в конструкторе и в какой то момент понимаешь, что он должен быть вложенным. Конечно в нашем примере никакой проблемы нет — можно просто все удалить и накидать запрос заново. Но на практике встречаются гораздо более сложные примеры, например, с несколькими уровнями вложенности, когда на то чтобы сделать запрос было потрачено несколько часов. И в этом случае есть достаточно простой выход. Можно воспользоваться встроенным в конструктор текстовым редактором запросов. Надо с помощью кнопки Запрос получить текст запроса (см. картинку выше) и скопировать его в буфер. Далее создаем новый вложенный запрос опять нажимаем кнопку Запрос , вставляем текст из буфера, жмем ОК. Соответственно старый запрос на верхнем уровне зачищаем. Таким образом мы при необходимости можем легко на лету создавать многоуровневые вложенные запросы.

Конструктор запроса имеет достаточно простой, интуитивно понятный интерфейс. Тем не менее рассмотрим применение конструктора запроса подробнее.

Запуск конструктора текста запроса производится контекстным меню (правой кнопкой мыши) в нужном месте программного кода.

Рассмотрим каждую вкладку конструктора подробнее. Исключение — вкладка Построитель, это тема для отдельного разговора.

Вкладка Таблицы и поля

На этой вкладке указывается источник данных и поля, которые необходимо выводить в отчет. По сути, тут описываются конструкции ВЫБРАТЬ … ИЗ.

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

В контекстном меню виртуальных таблиц можно задать параметры этих таблиц:

Вкладка Связи

Вкладка служит для описания соединений нескольких таблиц, создает конструкции со словом СОЕДИНЕНИЕ.

Вкладка Группировка

На данной вкладке система позволяет группировать и суммировать нужные поля результата таблицы. Описывается использование конструкций СГРУППИРОВАТЬ ПО, СУММА, МИНИМУМ, СРЕДНЕЕ, МАКСИМУМ, КОЛИЧЕСТВО, КОЛИЧЕСТВО РАЗЛИЧНЫХ.

Получите 267 видеоуроков по 1С бесплатно:

Вкладка Условия

Отвечает за всё, что идёт в тексте запроса после конструкции ГДЕ, т.е. за все условия, накладываемые на получаемые данные.

Вкладка Дополнительно

Вкладка Дополнительно изобилует всевозможными параметрами, которые являются очень важными. Рассмотрим каждое из свойств.

Группировка Выборка записей :

  • Первые N — параметр, возвращающий в запрос только N записей (оператор ПЕРВЫЕ)
  • Без повторяющихся — обеспечивает уникальность полученных записей (оператор РАЗЛИЧНЫЕ )
  • Разрешенные — позволяет выбирать только те записи, которые позволяет выбрать система с учетом (конструкция РАЗРЕШЕННЫЕ )

Группировка Тип запроса определяет, каким будет тип запроса: выборка данных, создание временных таблицы или же уничтожение временной таблицы.

Ниже существует флаг Блокировать полученные данные для последующего изменения . Он позволяет включить возможность установки блокировки данных, которая обеспечивает сохранность данных от момента их чтения до изменения (актуально только для Автоматического режима блокировок, конструкция ).

Вкладка Объединения/Псевдонимы

На этой вкладке конструктора запросов устанавливается возможность объединения разных таблиц и псевдонимы (конструкция КАК). В левой части указываются таблицы, если установить флаги напротив таблицы, будут использоваться конструкции ОБЪЕДИНИТЬ, иначе — ОБЪЕДИНИТЬ ВСЕ (отличия двух способов ). В правой части указываются соответствия полей в разных таблицах, если соответствие не указано, запрос будет возвращать NULL.

Вкладка Порядок

Здесь указывается порядок сортировки значений (УПОРЯДОЧИТЬ ПО) — по убыванию (УБЫВ) или возрастанию(ВОЗР).

Также есть интересный флаг — Автоупорядочивание (в запросе — АВТОУПОРЯДОЧИВАНИЕ). По умолчанию, система 1С 8.3 выводит данные в «хаотичном» порядке. Если установить этот флаг, система будет сортировать данные по внутренним данным.

Вкладка Пакет запросов

На вкладке конструктора запросов можно , а также использовать её в роли навигации. В тексте запроса пакеты разделяются символом «;»(точка с запятой).

Кнопка «Запрос» в конструкторе запросов

В левом нижнем углу конструктора запроса есть кнопка Запрос, с помощью которого можно в любой момент просмотреть текст запроса:

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