Back to top

Просмотр временных таблиц запроса 1С

Опубликовано e-1c@mail.ru - вт, 04/25/2017 - 10:20

При построении запросов, в языке 1с есть возможность получения результата выполнения запроса с помощью команды: " ПОМЕСТИТЬ <ИмяВременнойТаблицы> ", где <ИмяВременнойТаблицы> - имя "временной таблицы", которая является свойством объекта "Запрос" и представляет из себя объект типа МенеджерВременныхТаблиц, который описывает пространство имен временных таблиц и отвечает за их создание и уничтожение в базе данных. Данный механизм применяется для получения промежуточных данных запросов для дальнейшего их использования в других запросах, что позволяет сделать удобней их отладку, оптимизировать код, сделать запросы более читаемыми.

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

Добавляем к себе в модуль следующую функцию (серверную, если это управляемое приложение):

Функция ДанныеВТ(Запрос, ИмяВТ)
 
     ДанныеТаблицы = Новый Запрос;
     ДанныеТаблицы.Текст =
     "Выбрать *
     |    Из "+ИмяВТ+"
     |";
     Возврат ДанныеТаблицы.Выполнить().Выгрузить();
 
КонецФункции

Вызовем ее после текста запроса, например:

Запрос = Новый Запрос;
 
 
 
Запрос.Текст = "ВЫБРАТЬ
|ТЗИтоговая.Наименование
|ПОМЕСТИТЬ Итоговая
|ИЗ
|&ТЗИтоговая КАК ТЗИтоговая
|;
|//////////////////////////////////////////////////////////
|ВЫБРАТЬ
|*
|ПОМЕСТИТЬ Ном
|ИЗ
|Справочник.Номенклатура КАК Номенклатура
|;
|//////////////////////////////////////////////////////////
|ВЫБРАТЬ
|*
|ИЗ
|Итоговая КАК Итоговая
|   ЛЕВОЕ СОЕДИНЕНИЕ Ном КАК Ном
|   ПО Итоговая.Наименование = Ном.Наименование";
 
 
Запрос.МенеджерВременныхТаблиц = новый МенеджерВременныхТаблиц;
Запрос.выполнить();
Табл = ДанныеВТ(Запрос, "Итоговая");

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

Время жизни

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

При этом возможно уничтожить временную таблицу программным образом, выполнив в одном из пакетов запроса инструкцию "УНИЧТОЖИТЬ <ИмяВременнойТаблицы>". Тогда платформа выполняет SQL-команду "TRUNCATE" на уничтожение временной таблицы.

При использовании менеджера временных таблиц, если таблицы не были явно уничтожены разработчиком (инструкция запроса "УНИЧТОЖИТЬ", сброс менеджера временных таблиц в "Неопределено" или методом "Закрыть()"), то платформа уничтожает их самостоятельно после того, как был уничтожен контекст, в рамках которого они были сформированы. Другими словами, объект будет уничтожен при завершении процедуры или функции, в которой он был создан.

Влияние на производительность

Использование временных таблиц позволяет существенно снизить нагрузку на SQL-сервер за счет многократного использования ранее сформированной выборки из таблицы в других запросах. Конечно, создание и хранение временных таблиц занимает дополнительные ресурсы, но, по сравнению с тратой ресурсов при повторных запросах к таблицам, этот вариант более оптимальный.

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

Вывод

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

Самым главным аргументом в пользу использования временных таблиц является то, что их использование позволяет SQL-серверу строить более оптимальные планы запросов.