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

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

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

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

 

14 Comments

  1. noprogrammer

    не совсем понятно в чем выигрыш…. неужели «записать» уже подготовленные движения дольше чем:

    1.Прочитать все движения до проведения

    2.сравнить все движения фактически после проведения (с тем что было)

    ?

    Reply
  2. alexk-is

    (1) Это как раз просто.

    Если в движениях нет разницы, то их можно не записывать. Соответственно «»записать» уже подготовленные движения» дольше чем их не записывать совсем. 🙂

    Reply
  3. noprogrammer

    (2)

    Если в движениях нет разницы, то их можно не записывать. Соответственно «»записать» уже подготовленные движения» дольше чем их не записывать совсем. 🙂

    Время затраченное на чтение движений «до», сравнение движений «после» как мне кажется большее чем время на «запись» уже готовых движений.

    + не совсем понятно, что происходит с «удалением движений» перед проведением (такое ощущение, что они вообще не трогаются)

    Reply
  4. sebe

    (3) время на запись больше чем время сравнения (опытным путем). «Удаление движения» это при отмене проведения.

    Reply
  5. sebe

    (3) если логически подумать то на жесткий диск запись идет медленее чем чтение, а расчет сравнения двух таблиц вообще почти моментально по сравнению с записью и чтением.

    Reply
  6. alexk-is

    (3) Можно выделить 3 режима проведения документов:

    1. Проведение новых

    2. Проведение проведенных без внесения изменений

    3. Проведение измененных проведенных документов

    При «проведении новых» сравнивать нечего, поэтому для них ничего не меняется

    При «проведении проведенных без внесения изменений» только сравниваем и нечего не записываем

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

    При массовом проведении документов большинство из них попадают в категорию «проведение проведенных без внесения изменений». Отсюда и ускорение

    Reply
  7. sebe

    (6) так и есть что при перепроведении месяца производительность увеличивается в 2-3 раза, т.к. основная масса документов не меняет движений.

    Reply
  8. hogik

    (0)

    Идея очевидная. Странно, что в «штатных» средствах делается иначе. 😉

    По моему опыту работы с различными ИС — только в продуктах 1С делается «тупое» обновления не измененных данных без предварительного анализа.

    Reply
  9. pumbaE

    (8) даже хуже, если посмотреть как делают расчет зарплатных документов… (любой расчет очищает движения, делает заново рассчитывает и все … отказаться от нового расчета невозможно).

    Reply
  10. anig99

    (0) (9)

    http://www.sibeaz.ru/ver8111.shtml

    Прочее

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

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

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

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

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

    Хотя посмотрев код не вижу чего-то нового, кроме лишней процедуры на доп.проверку модифицированности. По-моему достаточно просто не очищать движения перед записью и платформа сама сравнит движения.

    Покажите код записи движений ДО Вашей оптимизации. Что-то было не так, если механизм платформы не работал.

    Reply
  11. aspirator23

    1с опубликовала год, а то и два назад технологию проведения документов как они это называют «по-новому». Описано в нескольких книжках и даже на сайте 1с в открытой части. Общее описание этих правил не бог весть какое сложное, но там более комплексно рассмотрено «правильное» проведение документов.

    Подразумевается перевод полностью или частично на управляемое проведение. То что описано в данной публикации — это только часть этой технологии. Не в обиду автору публикации.

    Reply
  12. dkprim

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

    Reply
  13. almas

    Спасибо, поднял интересную тему.

    Reply
  14. Rustig

    (0) просим код вместо картинки и двух предложений в студию ! 🙂

    я полагаю, пока 1С развивает эту тему в 8.2

    ты эту тему развернешь на 8.1 🙂

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *