Ускорение расчета себестоимости в УПП (партионный учет)

31.01.14

База данных - HighLoad оптимизация

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

Используем партионный учет. Списание партий "по средней".

Как то в очередной раз разбираясь с расчетом себестоимости я заметил такую вещь, что в файловой базе полный расчет выполнялся за 30 секунд, а в серверной порядка 10 минут.

Отладчиком был найден типовой код, выполнение которого занимало большую часть времени. Как это ни удивительно, это оказались запросы по способам распределения статей затрат организации в общем модуле ПроцедурыРасчетаСебестоимостиВыпуска.

Посмотрев текст запроса и просто добавив соответствующие индексы во временные таблицы по способам распределения мы получили ускорение при проведении документа «Расчет себестоимости» в серверной базе почти в 20 раз (10 минут => 30 секунд).

Здесь следует сделать одно замечание: данный способ хорошо работает только в том случае, если в результирующей временной таблице по способам распределения большое число записей. Проверить это просто – выполните запрос из процедуры СформироватьВременнуюТаблицуСпособыРаспределения в консоли. В моем случае в выборке было порядка 100 тыс. записей (90 способов распределения на ~ 1200 подразделений организации (у нас это объекты строительства с этапами)).

Ниже приведены фрагменты кода:

  1. В процедуру СформироватьВременнуюТаблицуСпособыРаспределения сразу после запроса добавляем строки (см. комментарии //ТВИ):

ТекстЗапросаСКомментариями = "

|ВЫБРАТЬ РАЗЛИЧНЫЕ

…(полный текст запроса)...

|";

 

 

//

            ТекстЗапросаСКомментариями = ТекстЗапросаСКомментариями + "ИНДЕКСИРОВАТЬ ПО

|           СтатьяЗатрат,

|           Подразделение,

|           //ДляБухУчета СчетЗатрат,

|           //ДляНалУчета СчетЗатрат,

|           //ДляМеждУчета СчетЗатрат,

|           Период";

//


  1. В функцию СформироватьЗапросПоСпособамРаспределенияЗатрат сразу после строки ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "//Поместить", ""); добавляем следующие строки (см. комментарии //ТВИ):

           

Если ФормироватьВременнуюТаблицу Тогда

                        ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "//Поместить", "");

                        //

                        Если ВидОтраженияВУчете = Перечисления.ВидыОтраженияВУчете.ОтражатьВУправленческомУчете Тогда

                                   ТекстЗапроса = ТекстЗапроса + "ИНДЕКСИРОВАТЬ ПО

                                                           СпособыРаспределения.СтатьяЗатрат,    

                                                           СпособыРаспределения.Подразделение";

                        Иначе

                                   ТекстЗапроса = ТекстЗапроса + "ИНДЕКСИРОВАТЬ ПО

                                                           СпособыРаспределения.СтатьяЗатрат,    

                                                           СпособыРаспределения.Подразделение,

                                                           СпособыРаспределения.СчетЗатрат";

                        КонецЕсли;

                        //

ускорение расчет себестоимости УПП

См. также

Помощник закрытия месяца

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

В современных конфигурациях УТ 11, КА 2, ERP 2 и их аналогах присутствует механизм закрытия периода. Но при ошибках учета закрыть период корректно становится практически невозможно! Давайте попробуем разобраться, как можно устранить ошибки и закрыть корректно месяц!

9000 руб.

20.03.2018    69845    266    58    

292

Обработка "Списание доходов будущих периодов" и расширение

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

Решение регламентирует учет доходов будущих периодов(ДБП) в организации: сохраняет подробную информацию о объекте ДБП. По окончании месяца на основе введенной информации формируются проводки списания ДБП, отчеты для бухгалтерского и налогового учета. Подходит как для различных версий Бухгалтерии 8.3, так и для ERP и КА.

5500 руб.

09.10.2020    18710    40    18    

36

Ускоренное проведение документов (x4), устранение ошибок 60/62 счетов и зачет авансов (Бухгалтерия 3.0)

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    27372    79    146    

59

Автоматическое закрытие месяца в УНФ

Закрытие периода Платформа 1С v8.3 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 Россия Управленческий учет Платные (руб)

Закрытие месяца в Управлении нашей фирмой — это очень важная задача, которую надо выполнять регулярно. Как обычно, все важное и регулярное делать мы почему-то забываем =)

3600 руб.

30.09.2022    7234    12    0    

11

Исправление ошибки закрытия месяца "Обнаружены ненулевые остатки по суммам при нулевом остатке по количеству в регистре себестоимости по организации". УТ 11.4,УТ 11.5, КА 2.4,КА 2.5, ERP 2.4, ERP 2.5, КА 2 Казахстан, Управление торговлей 3 для Казахстана

Закрытие периода Корректировка данных Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 11 Управленческий учет Платные (руб)

Закрытие месяца - важный процесс в современных конфигурациях, таких как УТ 11.4, УТ 11.5, КА 2.4, КА 2.5 ERP 2.4,ERP 2.5, КА 2 Казахстан, УТ 3 Казахстан регламентные операции влияют на расчет себестоимости, и ошибки в данном расчете не дают картины деятельности организации.

2400 руб.

27.10.2021    22318    299    35    

71

Помощник исправления развернутого сальдо по видам запасов и ГТД

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

Обработка позволяет исправить развернутое сальдо по видам запасов, которое осталось после штатной обработки перепроведения документов. Подходит для конфигураций: УТ 11, КА 2, ERP

2400 руб.

15.07.2017    62537    143    45    

140

SALE! 20%

Заполнение документа "Корректировка регистров" произвольными данными

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

Внешняя обработка, позволяющая произвольным образом заполнять документ "Корректировка регистров" Предназначена для использования в конфигурациях "Управление торговлей 11", "Управление небольшой фирмой", "ERP Управление предприятием", а также в других конфигурациях, в состав которых входит библиотека стандартных подсистем (БСП) версии 2.2+ и указанный выше документ.

2400 1920 руб.

13.07.2015    50164    171    29    

121
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. kapustinag 05.02.14 10:45 Сейчас в теме
Воспользовался Вашим советом и получил сначала на тестовой базе, а потом и на рабочей ускорение расчета себестоимости по бух.учету примерно в 2.5 - 3 раза. Проведение документа было 2ч 40 минут - 2ч 50 минут - стало 50 минут - 1 ч.
Временная таблица, которую индексировали в функции СформироватьВременнуюТаблицуСпособыРаспределения(), у меня содержит 142000 строк.

Думаю, программисты фирмы 1С не предполагали в ней такого большого количества строк.
А, если вдуматься, разбухание этой таблицы практически неизбежно на производственной информационной базе - хотя бы из-за пометки на удаление некоторых подразделений и создания новых. Старые-то подразделения удалить нельзя.
user712426; V.Nikonov; +2 Ответить
3. wolfsoft 2421 05.02.14 11:23 Сейчас в теме
(1) kapustinag, есть стойкое ощущение, что программисты 1с вообще не предполагают, как их детища будут работать на реальных предприятиях...
Zerocool-2013; +1 Ответить
2. kapustinag 05.02.14 10:50 Сейчас в теме
На самом деле, при внимательном взгляде на запросы в этом общем модуле ПроцедурыРасчетаСебестоимостиВыпуска, видны еще возможности для ускорения.
Попробую; напишу, если будет существенный эффект.
4. I_r_a 11.02.14 11:01 Сейчас в теме
Раньше себестоимость считалась 20-30 мин, сейчас около 5 минут, большое спасибо.
user712426; +1 Ответить
6. olbu 10.10.14 09:59 Сейчас в теме
(4) I_r_a,
Доброго времени суток!
Можно у вас спросить, как вы добились таких скоростных результатов?
Исключая "железо"...
Может какие настройки у вас на это повлияли? у нас проведение РСВ длится уже 2 часа...
5. olbu 07.10.14 10:15 Сейчас в теме
Вот и я столкнулся с этой проблемой... РСВ БУ проводится около 1,5 часа, финансисты в ужасе...
сделал как тут указано... скорость проведения, со слов финансистов не изменилась...
сисадмин уже провел все возможные комбинации с sql и 1с сервером, теперя все косые взгляды на меня... :(

Вопрос:
Используется "котловой" метод, 2 номенклатурные группы, Партионный учет... Без 40 счета...
Может есть какие - либо настройки в УПП, влияющие на скорость проведения РСВ?
Оставьте свое сообщение