Оптимизация проведения документов по регистрам

Опубликовал Сергей Белоус (sebe) в раздел Программирование - Практика программирования

Оптимизация проведения документа по регистрам. Увеличение производительности перепроведения базы в 2-3 раза.

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

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

 

Скачать файлы

Наименование Файл Версия Размер
пример использования механизма (1 документ)
.dt 251,73Kb
19.09.11
55
.dt 251,73Kb 55 Скачать

См. также

Комментарии
1. noprogrammer (noprogrammer) 20.09.11 14:31 Сейчас в теме
не совсем понятно в чем выигрыш.... неужели "записать" уже подготовленные движения дольше чем:
1.Прочитать все движения до проведения
2.сравнить все движения фактически после проведения (с тем что было)
?
2. Алексей Константинов (alexk-is) 6115 20.09.11 14:44 Сейчас в теме
(1) Это как раз просто.
Если в движениях нет разницы, то их можно не записывать. Соответственно ""записать" уже подготовленные движения" дольше чем их не записывать совсем. :)
3. noprogrammer (noprogrammer) 20.09.11 14:48 Сейчас в теме
(2)
Если в движениях нет разницы, то их можно не записывать. Соответственно ""записать" уже подготовленные движения" дольше чем их не записывать совсем. :)


Время затраченное на чтение движений "до", сравнение движений "после" как мне кажется большее чем время на "запись" уже готовых движений.
+ не совсем понятно, что происходит с "удалением движений" перед проведением (такое ощущение, что они вообще не трогаются)
4. sergb (sebe) 20.09.11 14:57 Сейчас в теме
(3) время на запись больше чем время сравнения (опытным путем). "Удаление движения" это при отмене проведения.
5. sergb (sebe) 20.09.11 15:00 Сейчас в теме
(3) если логически подумать то на жесткий диск запись идет медленее чем чтение, а расчет сравнения двух таблиц вообще почти моментально по сравнению с записью и чтением.
6. Алексей Константинов (alexk-is) 6115 20.09.11 15:03 Сейчас в теме
(3) Можно выделить 3 режима проведения документов:
1. Проведение новых
2. Проведение проведенных без внесения изменений
3. Проведение измененных проведенных документов

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

При массовом проведении документов большинство из них попадают в категорию "проведение проведенных без внесения изменений". Отсюда и ускорение
7. sergb (sebe) 20.09.11 15:08 Сейчас в теме
(6) так и есть что при перепроведении месяца производительность увеличивается в 2-3 раза, т.к. основная масса документов не меняет движений.
8. Владимир (hogik) 417 20.09.11 16:21 Сейчас в теме
(0)
Идея очевидная. Странно, что в "штатных" средствах делается иначе. ;-)
По моему опыту работы с различными ИС - только в продуктах 1С делается "тупое" обновления не измененных данных без предварительного анализа.
9. sergb (sebe) 20.09.11 16:35 Сейчас в теме
(8) Былобы хорошо чтоб сама платформа делала такую проверку. может когда нибудь реализуют.
10. Евгений Сосна (pumbaE) 527 20.09.11 16:55 Сейчас в теме
(8) даже хуже, если посмотреть как делают расчет зарплатных документов... (любой расчет очищает движения, делает заново рассчитывает и все ... отказаться от нового расчета невозможно).
11. Александр Медведев (anig99) 2513 20.09.11 22:46 Сейчас в теме
(0) (9)
http://www.sibeaz.ru/ver8111.shtml
Прочее
Ускорено перепроведение документов, выполняющих движения по регистру бухгалтерии, в тех случаях, когда не используется автоматическое удаление движений и не изменяются движения документа. Теперь, если новый набор записей совпадает со старым набором записей, сохраненным в базе данных, перезапись набора записей регистра бухгалтерии в базе данных не происходит.

Где в следующих редакциях распространили на другие регистры.

В 8.2 появилась возможность самому устанавливать режим записи.

В принципе, не работает, если предварительно очищать и записывать движения.

Так что пока "-" за незнание мат.части. Даже, если Ваше решение лучше поведения платформы при ПРАВИЛЬНОЙ работе с движениями в режиме проверки модифицированности, то не раскрыто почему это так или почему это не работает в типовых или у Вас до оптимизации.
Хотя посмотрев код не вижу чего-то нового, кроме лишней процедуры на доп.проверку модифицированности. По-моему достаточно просто не очищать движения перед записью и платформа сама сравнит движения.

Покажите код записи движений ДО Вашей оптимизации. Что-то было не так, если механизм платформы не работал.
Прикрепленные файлы:
pumbaE; Evg-Lylyk; Borisych; +3 Ответить
12. aspirator 23 (aspirator23) 298 21.09.11 22:02 Сейчас в теме
1с опубликовала год, а то и два назад технологию проведения документов как они это называют "по-новому". Описано в нескольких книжках и даже на сайте 1с в открытой части. Общее описание этих правил не бог весть какое сложное, но там более комплексно рассмотрено "правильное" проведение документов.
Подразумевается перевод полностью или частично на управляемое проведение. То что описано в данной публикации - это только часть этой технологии. Не в обиду автору публикации.
13. Александр Иванов (dkprim) 4 22.09.11 14:31 Сейчас в теме
не смотря на все минусы, озвученные здесь - публикация полезная. спасибо :)
14. Алексей Захаров (almas) 186 23.09.11 09:08 Сейчас в теме
Спасибо, поднял интересную тему.
15. г. Казань Рустем Гумеров (Rustig) 790 28.10.11 03:03 Сейчас в теме
(0) просим код вместо картинки и двух предложений в студию ! :)
я полагаю, пока 1С развивает эту тему в 8.2
ты эту тему развернешь на 8.1 :)
Оставьте свое сообщение