Уничтожитель временных таблиц пакета запросов

22.09.17

Разработка - Инструментарий разработчика

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Уничтожитель временных таблиц пакета запросов:
.epf 9,40Kb ver:1.0
8
8 Скачать (1 SM) Купить за 1 850 руб.

Если вы пишете большие отчеты, используя множество временных таблиц в запросе, то для экономии памяти желательно уничтожать ВТ, которые дальше не будут использоваться при выполнении пакета запросов.

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

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

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

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

Протестировано на платформах 8.3.9, 8.3.10, но должно работать, начиная с платформы 8.3.5. Конфигурация не важна. Исходный запрос для обработки надо брать тот, который выполняется без ошибок в той же конфигурации.

обработка запросы уничтожить объектная модель запроса

См. также

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

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

12000 руб.

02.09.2020    171853    962    403    

924

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14351    109    46    

108

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

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

22200 руб.

06.10.2023    17307    43    15    

75

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

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

9360 руб.

17.05.2024    27298    96    48    

138

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

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

15000 руб.

10.11.2023    11911    45    27    

67

SALE! %

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

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

4800 3840 руб.

14.01.2013    191266    1152    0    

920

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    18097    7    32    

42

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1128    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. zekrus 151 27.09.17 08:05 Сейчас в теме
Доброе утро!
- "Лед тронулся господа ..."
Жду не дождусь когда увижу код:
Запрос.Текст="ВСТАВИТЬ ..."
С уважением
3. SerVer1C 863 27.09.17 09:01 Сейчас в теме
(1) Представьте, что вы пишите большой аналитический отчет, достающий данные из 20+....30+....50+ таблиц (sql). Соответственно у вас (возможно) будет несколько десятков временных таблиц. Причем могут быть и подзапросы, в которых идет обращение к ВТ. Конечно, можно пройтись по такому запросу вручную, и вставлять уничтожения ВТ по мере необходимости (для экономии памяти). Но "скормив" текст запроса данной обработке, она сама вставит уничтожения ВТ в текст запроса в те места текста запроса, после которого ВТ уже не будет востребована ниже по тексту. Может быть вы не поняли функционал данной обработки?
5. zekrus 151 27.09.17 11:17 Сейчас в теме
(3)Добрый день!
Возможно я не понятно объяснил, меня интересует возможность из запроса выполнить запись в таблицу СУБД.
С уважением
7. SerVer1C 863 27.09.17 11:35 Сейчас в теме
(5) Это было бы интересно, но фирма 1С на это не пойдет, т. к. при таком подходе может произойти рассогласование между платформой и данными в скуле.
2. DenisCh 27.09.17 08:46 Сейчас в теме
Грохнуть менеджер временных таблиц - не проще будет?
4. SerVer1C 863 27.09.17 09:04 Сейчас в теме
(2) Проще, но перед "Грохнуть" у вас память может быть занята гигабайтами данных временных таблиц. Поэтому будет лучше своевременно подчищать за собой неиспользуемые ВТ по мере необходимости.
6. VmvLer 27.09.17 11:28 Сейчас в теме
если создан запрос где

20+....30+....50+ таблиц

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

Я хочу сказать, что если на написание пакетного запроса потрачено более часа времени, то лучше потратить еще 5-10 минут в финале на удаление временных осознанно, а не автоматически.

хотя как "черновик" удаления эта обработка может и прокатит.
Infector; +1 Ответить
8. SerVer1C 863 27.09.17 11:38 Сейчас в теме
(6) Как понять "логика удаления временных таблиц может быть НЕ линейной" ? Если ВТ в пакете запросов дальше не используется, то на этом шаге ее можно (нужно) уничтожить. Обработка "осознанно" находит это место в пакете )
9. kiruha 388 28.09.17 11:07 Сейчас в теме
(8)
Бывают исключения - если задан Менеджер временных таблиц, то временная таблица может использоваться в другом запросе.
Еще бывает что подменяют текст запроса в зависимости от настроек (СтрЗаменить)
10. SerVer1C 863 28.09.17 11:33 Сейчас в теме
(9) Естественно, если программист использует МВТ, то в таком случае человек должен сам решать, какие ВТ ему далее потребуются в работе, но и при таком варианте обработка подскажет, какие "использованные" ВТ можно уничтожить, останется только руками убрать уничтожения для тех ВТ, которые будут использоваться в следующих запросах. Ну а через "СтрЗаменить" вообще можно прийти к совершенно другому запросу, не имеющему связи с исходным, так что тут автоматизировать нечего...
11. Wrols 90 05.10.18 07:33 Сейчас в теме
За публикацию - большое спасибо!
Вот только хотелось бы использовать не только в управляемых формах, но и обычных.

И можно было бы ещё одну штуку прикольную сделать: изменять порядок запросов в пакете, чтобы временные таблицы "жили" недолго.
К примеру, если какая-то временная таблица формируется первой, а используется только в 10 запросе пакета, то лучше и формирование этой временной таблицы сдвинуть на 9-е место.
12. SerVer1C 863 05.10.18 09:53 Сейчас в теме
(11) Спасибо за идею. Постараюсь реализовать. В текущем алгоритме обнаружил ошибки при наличии в пакете нескольких запросов с выводом результата. Со временем выложу исправление.
13. ~Ponk@~ 14 21.05.21 14:51 Сейчас в теме
Обработка не поддерживается больше? Не работает совсем

Недопустимое значение параметра (параметр номер '2')
{ВнешняяОбработка.УничтожениеВременныхТаблиц.Форма.Форма.Форма(223)}: Схема.ПакетЗапросов.Сдвинуть(Схема.ПакетЗапросов.Количество() - 1, -й + дельта);
{ВнешняяОбработка.УничтожениеВременныхТаблиц.Форма.Форма.Форма(76)}: ДобавитьУничтоженияВСхему(Схема, Дерево, ДобавлятьВКонецЗапроса, УдалятьНеиспользуемые);
{ВнешняяОбработка.УничтожениеВременныхТаблиц.Форма.Форма.Форма(38)}: ПреобразоватьСхемуЗапроса(СхемаЗапроса, ДобавлятьВКонецЗапроса, УдалятьНеиспользуемые);
{ВнешняяОбработка.УничтожениеВременныхТаблиц.Форма.Форма.Форма(24)}: РазборЗапросаНаСервере();

по причине:
Недопустимое значение параметра (параметр номер '2')
14. SerVer1C 863 21.05.21 15:15 Сейчас в теме
(13) Никак не доберусь доделать новую версию... Скиньте в личку запрос (если не секретный). Скоро выложу исправленную версию.
15. SeiOkami 3533 10.04.24 21:38 Сейчас в теме
О, прикольно, не я один когда-то этой жутью занимался.
Мой вариант: https://infostart.ru/1c/tools/418420/
Не факт, что до сих пор работает, было давно)
Оставьте свое сообщение