Дамп временных таблиц для ЗапросВСтрокуXML(...)

25.08.22

Разработка - БСП (Библиотека стандартных подсистем)

Облегчаем отладку запросов.

На текущий момент для отладки запросов, в основном, использую консоль запросов из поставки БСП. В этой консоли удобно пользоваться "импортом" запроса из XML. Этот XML предоставляет типовая ф-я БСП ОбщегоНазначения.ЗапросВСтрокуXML(...).

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

Матюкнувшись в очередной раз, решил написать обертку над штатной ЗапросВСтрокуXML(...), чтобы в сериализуемом запросе зафиксировать данные временных таблиц.

// Выгружает запрос в строку XML, которую можно вставить в Консоль запросов.
// Работает с помощью одноименного метода БСП ОбщегоНазначения.ЗапросВСтрокуXML(...).
// В дополнение к ее функционалу, реализовано снятие дампа временных таблиц и внедрение в запрос кода и параметров для 
// заполнения временных таблиц на основании параметров запроса типа ТаблицаЗначений.
//
// Параметры:
//  Запрос						 - Запрос	 - запрос, который необходимо выгрузить в формат строки XML.
//  ЗаполнитьВременныеТаблицы	 - Булево, Неопределено	 - Нужно ли дополнять запрос кодом и данными для создания временных таблиц.
//		При значении =Неопределено, необходимость определяется автоматически, исходя из наличия менеджера временных таблиц у Запроса, 
//		и есть ли временные таблицы, управляемые менеджером.
// 
// Возвращаемое значение:
//   Строка - строка в формате XML, которую можно извлечь при помощи метода "ОбщегоНазначения.ЗначениеИзСтрокиXML".
//       После извлечения получится объект типа "Структура" с полями:
//       * Текст     - Строка - текст запроса.
//       * Параметры - Структура - параметры запроса.
//
Функция ЗапросВСтрокуXML(Запрос, Знач ЗаполнитьВременныеТаблицы = Неопределено) Экспорт

	// Авто-определение необходимости заполнения.
	ЗаполнитьВТ = Запрос.МенеджерВременныхТаблиц<>Неопределено И Запрос.МенеджерВременныхТаблиц.Таблицы.Количество()<>0;
	// Уточняем исходя из значения параметра ЗаполнитьВременныеТаблицы.
	Если ТипЗнч(ЗаполнитьВременныеТаблицы)=Тип("Булево") Тогда 
		ЗаполнитьВТ = ЗаполнитьВТ И ЗаполнитьВременныеТаблицы;
	КонецЕсли;
	
	Если Не ЗаполнитьВТ Тогда
		Возврат ОбщегоНазначения.ЗапросВСтрокуXML(Запрос); // Внимание! Ранний возврат.
	КонецЕсли;
	
	// Будем работать с копией Запроса
	КопияЗапроса = Новый Запрос;
	КопияЗапроса.МенеджерВременныхТаблиц = Запрос.МенеджерВременныхТаблиц;
	
	СоставТекстаЗапроса = Новый Массив; // Здесь будем собирать все части будущего запроса с дампами таблиц.
	Для Каждого ОписаниеТаблицы Из КопияЗапроса.МенеджерВременныхТаблиц.Таблицы Цикл
		
		// Снимаем дамп временной таблицы.
		КопияЗапроса.Текст = СтрШаблон("ВЫБРАТЬ * ИЗ %1", ОписаниеТаблицы.ПолноеИмя);
		ДанныеТаблицы = КопияЗапроса.Выполнить().Выгрузить();
		// Устанавливаем полученную таблицу в параметр запроса.
		ИмяПараметраТаблица = "Внеш" + ОписаниеТаблицы.ПолноеИмя;
		КопияЗапроса.УстановитьПараметр(ИмяПараметраТаблица, ДанныеТаблицы);
		// Конструируем текст запроса для помещения таблицы значений во временную таблицу.
		ИменаПолейТаблицы = Новый Массив;
		Для Каждого Колонка Из ОписаниеТаблицы.Колонки Цикл
			// Увы, но есть проблема с "виртуальными" полями. 
			// Поэтому обрабатывать УИДы и хранилища значений не будем.
			// https://its.1c.ru/db/v8312doc/bookmark/dev/TI000001778
			Если Колонка.ТипЗначения.СодержитТип(Тип("УникальныйИдентификатор"))
				Или Колонка.ТипЗначения.СодержитТип(Тип("ХранилищеЗначения"))
			Тогда
				Продолжить;
			КонецЕсли;
			ИменаПолейТаблицы.Добавить("вн." + Колонка.Имя);
		КонецЦикла;
		// Собираем строка запроса пакета запросов, добавляем ее в массив составляющих.
		СтрокаИменПолей = СтрСоединить(ИменаПолейТаблицы, ", ");
		СоставТекстаЗапроса.Добавить(СтрШаблон("ВЫБРАТЬ %1 ПОМЕСТИТЬ %2 ИЗ &%3 КАК вн;", 
			СтрокаИменПолей, ОписаниеТаблицы.ПолноеИмя, ИмяПараметраТаблица));
		
	КонецЦикла;
	// В финале добавляем исходный запрос.	
	СоставТекстаЗапроса.Добавить(Запрос.Текст);	
	КопияЗапроса.Текст = СтрСоединить(СоставТекстаЗапроса, "
	|");
	// Заполняем параметры
	Для Каждого ОписаниеПараметра Из Запрос.Параметры Цикл
		КопияЗапроса.УстановитьПараметр(ОписаниеПараметра.Ключ, ОписаниеПараметра.Значение);
	КонецЦикла;
	КопияЗапроса.МенеджерВременныхТаблиц = Неопределено; // Ну на всякий случай.
	// Вызываем оригинальный метод.
	Возврат ОбщегоНазначения.ЗапросВСтрокуXML(КопияЗапроса);
	
КонецФункции

Будет работать на платформах с 8.3.8. Версия БСП может быть использована любая.

См. также

Создать на основании - своя кнопка (БСП). Проблема двух подменю Создать на основании

БСП (Библиотека стандартных подсистем) Адаптация типовых решений Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

Понадобилось в подменю "Создать на основании" добавить свою команду, которая открывает обработку. В процессе доработок появилась проблема двух подменю "Создать на основании". В статье о том, как решились проблемы.

01.03.2024    1282    dimanich70    6    

13

Заполнение поля адреса в своей обработке [БСП]

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

Небольшая шпаргалка по функциям БСП касательно адреса. Так скажем, еще один способ помимо https://infostart.ru/1c/articles/1060970/

12.02.2024    687    FilippovRI    0    

15

Расширяем возможности дополнительных обработок и настраиваем их отладку

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

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

07.02.2024    2351    YA_418728146    11    

40

1С:БСП Дополнительные реквизиты и сведения

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

В этой статье расскажем об архитектуре, использовании и особенностях реализации подсистемы «Свойства» из инструментария разработчика «1С:Библиотека стандартных подсистем» (1С: БСП).

19.01.2024    5162    PROSTO-1C    5    

45

Бесплатный митап 9 февраля «Библиотеки и фреймворки на 1С и всё, что с этим связано»

БСП (Библиотека стандартных подсистем) Мероприятия Бесплатно (free)

Митап посвящен вопросам создания, использования и поддержке переиспользуемого кода при разработке решений на платформе 1С:Предприятие 8.

15.01.2024    3798    0    Infostart    0    

20

Шаблоны новых объектов 1С для 1С:Бухгалтерии предприятия

Инструментарий разработчика БСП (Библиотека стандартных подсистем) Механизмы типовых конфигураций Платформа 1С v8.3 1С:Бухгалтерия 3.0 Бесплатно (free)

Используются для создания новых объектов в конфигурации, чтобы не забыть, что нужно сделать. Сделано на примере 1С:Бухгалтерия предприятия, в других конфигурациях могут быть другие, а могут быть и похожие объекты.

28.12.2023    4831    mrXoxot    11    

99
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. RustIG 1351 25.08.22 11:18 Сейчас в теме
сколько врем. таблиц можно передать?
2. ImHunter 312 25.08.22 11:24 Сейчас в теме
(1) Сколь угодно. Лишь бы потом Строка все содержимое вместила.
3. triviumfan 92 29.08.22 21:27 Сейчас в теме
На текущий момент для отладки запросов, в основном, использую консоль запросов из поставки БСП.

Дальше не осилил. Извини.
Оставьте свое сообщение