gifts2017

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

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

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

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

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

 

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

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

См. также

Подписаться Добавить вознаграждение

Комментарии

1. noprogrammer (noprogrammer) 20.09.11 14:31
не совсем понятно в чем выигрыш.... неужели "записать" уже подготовленные движения дольше чем:
1.Прочитать все движения до проведения
2.сравнить все движения фактически после проведения (с тем что было)
?
2. Алексей Константинов (alexk-is) 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) 20.09.11 15:03
(3) Можно выделить 3 режима проведения документов:
1. Проведение новых
2. Проведение проведенных без внесения изменений
3. Проведение измененных проведенных документов

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

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

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

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

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

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

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