Что может влиять на производительность макроса?

Автор adi_den2013, 3 апреля 2014, 08:19

0 Пользователи и 1 гость просматривают эту тему.

adi_den2013

Выполнение макроса (последовательно) несколько раз замедляет его работу  ???  В чем причина?  Добавила после чистки временных таблиц CHECKPOINT DEFRAG и сохранение файла

   document = ThisComponent.CurrentController.Frame
   dispatcher = createUnoService("com.sun.star.frame.DispatchHelper")
   dispatcher.executeDispatch(document, ".uno:Save", "", 0, Array())

не помогает.
Яна (in real)

JohnSUN

Владислав Орлов aka JohnSUN
Благодарить-не зазорно.
Подарить благо создателям офиса, нашему ресурсу, мне

adi_den2013

#2
Если схематично:

1. DROP [temp_table]               удаление временных таблиц

2. DELETE FROM [base_table]    очистка основной таблицы

3. SELECT FROM                     заполнение временных таблиц расчетами по разным условиям

4. INSERT INTO                      вставка в основную таблицу выбранных данных

5. UPDATE                             корректировка основной таблицы под отчет

Есть некоторая мысль, но не уверена что она правильная. В основной таблице есть ключевое поле с автозаполнением - ID. Может в этом тормоза? Каждый раз на это тратится время?

Да и еще - база внутренняя.
Яна (in real)

JohnSUN

И, говоришь, время выполнения плавно нарастает от запуска к запуску?

С автоинкрементным айдишником вряд ли связано - набор данных от запуска к запуску один и тот же? Ну, количество обрабатываемых записей сопоставимо по количеству?

Можно, конечно добавить пункт 2б, что-то вроде
ALTER TABLE [base_table] ALTER COLUMN "ID" RESTART WITH 0
Но вряд ли поможет.

Попробуй в диспетчере задач понаблюдать за расходом памяти. Возможно, просто где-то "утечка памяти" - забиваешь все мозги и включается своп, отсюда и тормоза
Владислав Орлов aka JohnSUN
Благодарить-не зазорно.
Подарить благо создателям офиса, нашему ресурсу, мне

adi_den2013

Вообще-то макрос должен работать 7-10 секунд, как мне казалось .

Диспетчер задач ничего "страшного", грузящего мозги, не показал.  Записала avi-файл с экрана, но получился большой - сюда не прицепишь. Могу только скрин привесить.

[вложение удалено Администратором]
Яна (in real)