Регистры в системе 1С:Предприятие 7.7.: как есть, как должно быть?

В данной статье будет описана реализация обЪекта "Регистр" в системе 1С:Предприятие 7.7. Подробно будут рассмотрены все возможности, влияющие на структуру и производительность работы с обЪектом "Регистр". Будет проведен анализ текущей реализации и представлен мой взгляд на то какой она должна быть. Итак обЪект "Регистр", что же он из себя представляет? Если отвлечься от физической реализации, то это таблица состоящая из полей нескольких видов:

Шемякин Павел, май 2002
Оригинал статьи на http://1csql.virtualave.net

В данной статье будет описана реализация обЪекта "Регистр" в системе 1С:Предприятие 7.7. Подробно будут рассмотрены все возможности, влияющие на структуру и производительность работы с обЪектом "Регистр". Будет проведен анализ текущей реализации и представлен мой взгляд на то какой она должна быть.

Итак обЪект "Регистр", что же он из себя представляет? Если отвлечься от физической реализации, то это таблица состоящая из полей нескольких видов:

1. Измерения - ключевые поля. По умолчанию ключ составляется из всех полей данного типа конкатенацией их в порядке задания в конфигурации.
2. Ресурсы - числовые поля, для каждого из которых определены несколько функций
3. Реквизиты - аналог поля Измерения, с ограничением на функции по Ресурсам.

Однако регистр это не обычная таблица. К нему можно применить термин функциональная таблица, то есть содержимое таблицы зависит от некоторых переменных. В случае с регистром это период, то есть две переменные: начало периода, конец периода. В новой версии системы 1С 8.0 такую таблицу называют виртуальной.

В зависимости от типа регистра: остаточный или оборотный, изменяется набор функций. В первом случае это четыре функции: НачОст, Приход, Расход, КонОст, во втором: только одна - Сумма. Для остаточного регистра функции НачОст, КонОст для полей типа реквизит не определены.

Рассмотрим теперь физическую реализацию обЪекта "Регистр" в системе 1С:Предприятие 7.7. Описание будем проводить для 1С:Предприятие 7.7 SQL версии 18 релиз.

Остаточный регистр

Реализуется с помощью двух таблиц: RGxxx и RAxxx.

Первая таблица содержит значения функции НачОст на начало каждого периода указанного в меню системы "Операции - Управление оперативными итогами" в секции "Периодичность сохранение остатков". Значение данной функции может хранится на начало каждой пятидневки, десятидневки, на начало каждых пятнадцати дней, на начало каждого месяца. Для каждого регистра данная опция действует одинаково, таким образом нет возможности установить разную периодичность для разных регистров.

Замечу, что кроме функции НачОст можно также получить и функцию КонОст, так как остаток на начало текущего периода является остатком на конец предыдущего. Если вам нужно получить остаток на начало какого-то периода, то для поля PERIOD вы должны указать значение начала предыдущего периода (то есть НачОст(01.01.2002) ~ PERIOD = 20020112).

Таблица имеет индекс по умолчанию PERIOD + (конкатенация измерений в порядке следования их в конфигурации). Поэтому вы должны учитывать, последовательность расположения измерений. Первым должно следовать измерение, по которому наиболее часто будет задаваться условие для выборки и так далее. Кроме того имеется возможность создать дополнительные индексы для каждого измерения кроме первого (и это правильно так как индекс для первого измерения уже задан). Для этого в конфигураторе зайдите в свойства измерения на закладку "Дополнительные" и поставьте галку "Отбор итогов". Задать индекс для произвольного набора измерений невозможно.

Вторая таблица содержит все движения записанные документов в модуле проведения. В поле IDDOC содержится идентификатор документа, которому принадлежат эти движения в поле DEBKRED содержится знак движения (0 - приход, 1 - расход). Таким образом данная таблица служит для расчета функций Приход и Расход за выбранный период. Замечу, что поля типа "Реквизит" хранятся только в этой таблице, поэтому для них возможно вычисление только данных функций.

По умолчанию вычисление этих функций производится при помощи соединения с таблицей журналов документов (_1SJOURN) по идентификатору документа (при этом учитываются только проведенные документы, имеющие движения по данному регистру - эти условия указываются по полям CLOSED и RFxxx таблицы журналов). Соединение с таблицей журналов необходимо так как только там содержится дата документа, по которой можно определить входит движение в выбранный период или нет. Согласитесь, что это не есть хорошо. При вычислении оборотов скажем за месяц необходимо просканировать ВСЕ документы в таблице журналов за месяц. Однако данный недостаток можно устранить. Для этого предназначена галка "Быстрая обработка движений" в свойствах регистра. При этом в таблице движений появляется дополнительное поле DATE_TIME_IDDOC и индекс по нему, что позволяет не обращаться к журналу документов. Однако в 18 релизе данная возможность используется системой как-то странно: при получении остатков соединения с таблицей журналов уже нет, но для вычисления оборотов по прежнему идет соединение с таблицей журналов. Причем вычисление оборотов выполняется не просто с помощью отдельного запроса, а при помощи курсора.

По умолчанию в таблице присутствует только индекс по идентификатору документа (включающий также в себя номер строки документа и номер движения). Кроме этого можно добавить дополнительный индекс по измерению или по реквизиту. Для этого нужно в свойствах измерения или реквизита на закладке "Дополнительные" установить галку "Отбор движений". При этом создается индекс по этому реквизиту + либо идентификатор документа, либо поле DATE_TIME_IDDOC (если есть).

Вот так реализованы регистры в системе 1С. Надеюсь вы поняли как на самом деле это должно быть - в конце почти каждого абзаца были указаны недостатки. Суммируем их в рекомендации:

1. Возможность установки периодичности хранения остатков для каждого регистра отдельно.
2. Возможность определения произвольных индексов для таблицы итогов, движений. Возможность отключения индекса по умолчанию
3. Исправление ошибки и оптимизация при вычислении функций Приход и Расход

Хотел бы заметить еще один важный момент в реализации остаточных регистров. Судя по их названию они должны использоваться в основном для получения остатков, но зачастую их используют и для получения оборотов (различные ведомости). Однако вычисление оборотов при помощи регистров совершенно не оптимально. Мало того, что имеется уже описанная выше ошибка, но самое главное - чем больше период для получения оборотов тем дольше будет их вычисление и никакая оптимизация тут уже не поможет. В бухгалтерской подсистеме это сделано лучше - вместе с остатком там хранятся обороты по периодам. Конечно можно использовать для вычисления оборотов оборотные регистры, но зачем для этого заводить еще одну таблицу, когда можно сделать все в одной? Поэтому я считаю, что нужная еще одна рекомендация:

Возможность указания (может быть даже для каждого ресурса в отдельности) хранить итоговые обороты.

Оборотный регистр

В целом реализация оборотного регистра аналогична остаточному регистру. Оборотный регистр также состоит из таких же двух таблиц. Таблица движений полностью аналогична таблице движений остаточного регистра. Таблица итогов содержит не значение функции НачОст, а значение функции Сумма. Состав индексов у таблиц и их смысл такой же как у остаточного регистра. Для оборотного регистра уже учтено замечание 1 - периодичность можно устанавливать для каждого регистра отдельно. Периодичность оборотного регистра отличается от регистра остатков: день, неделя, декада, месяц, квартал, год. Итоги в таблице итогов по периодам хранятся нормально, то есть чтобы получить значение функции Сумма за целый период, поле период нужно приравнять началу выбранного периода (желательно указать условие на нахождение м/у началом и концом выбранного периода).

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

1. При выполнении запроса за нецелый период в функции Сумма, нужно учитывать знак движения
2. Необходимо ввести дополнительный признак - разделять или нет значения функций Приход и Расход для каждого ресурса (или регистра в целом). При этом если данный признак стоит, то использование ДвижениеПриходВыполнить/ ДвижениеРасходВыполнить и функций Приход/Расход не должно вызывать ошибку и наоборот.

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

Шемякин Павел, май 2002.

Начать дискуссию

🔥УСН-2025. Что хотят изменить?

Законопроекты за которыми нужно следить бухгалтеру, который хочет выжить в 2025 году.

Курсы повышения
квалификации

18
Официальное удостоверение с занесением в госреестр Рособрнадзора

ЕФС-1 подают на членов совета директоров, даже если нет выплат

Закон о персонифицированном учете обязывает подавать сведения не о факте заключения ГПД, а о дате его заключения и прекращения.

Как будут проводиться проверки деклараций по НДФЛ с 2025 года

В Бухгалтерии Ада появился третий автор - Валюшка. Это нейросеть, потому и Валя, хз девочка оно или мальчик.Сегодня Валюшке дали первое задание - просмотреть последние новости в области налогообложения и написать текст в блог.

Как будут проводиться проверки деклараций по НДФЛ с 2025 года
Лучшие спикеры, новый каждый день

НК РФ не устанавливает какой-нибудь перечень документов, которые подтверждают фактическое нахождение лиц на территории РФ

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

Бухгалтеры выбирают лучший сервис для сдачи отчетов, Роструд объяснил, как внести в трудовую книжку запись об увольнении по собственному. 👩‍💻«Ночной бухгалтер» № 1706

Бухгалтеры обсуждают, какой из сервисов сдачи отчетов лучший. И мы решили провести опрос на эту тему. Роструд объяснил, какая формулировка в трудовой книжке при увольнении по собственному желанию будет корректной. Больше половины россиян продолжают работать и в свое личное время. Стоит ли паниковать из-за падения акций.

Иллюстрация: Вера Ревина/Клерк.ру

Можно будет узнать реальные цены товаров на внутреннем рынке

Дмитрий Григоренко провел рабочую встречу с руководителем ФАС Максимом Шаскольским, который анонсировал создание в России системы ценовых рыночных индикаторов.

Опытом делятся эксперты-практики, без воды

Россия и Белоруссия будут согласовывать налоговую политику и создавать общий финансовый рынок

Утверждены планы мероприятий по исполнению Основных направлений реализации положений Договора о создании Союзного государства между Россией и Белоруссией на 2024–2026 годы.

Налоговики уточнили дату несения расходов в виде компенсации за авто сотрудника

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

Отпуска

Отпуск работников детсадов могут увеличить

Первый зампред комитета Госдумы по просвещению Яна Лантратова предложила увеличить продолжительность отпуска для работников детсадов с 42 до 56 дней.

Глава комитета Госдумы по бюджету и налогам объяснил причины увеличения дефицита федерального бюджета-2024

Андрей Макаров заявил, что финансирование нужно на ряд вопросов, которые были озвучены президентом Владимиром Путиным.

7 шагов к эффективному контент-плану для блога или сайта

Хороший контент-план — это не просто перечень тем для публикаций, это карта, которая поможет ориентироваться в материалах сайта или блога и двигаться в правильном направлении. Без такого плана легко заблудиться среди множества тем и форматов.

Бесплатно с Отчетность в СФР

ЕФС-1 при увольнении сотрудника: образец заполнения

Увольнение сотрудника — это процесс, который требует внимания к деталям. В этой статье мы даем пошаговую инструкцию и образец заполнения ЕФС-1 при увольнении работника. Вы узнаете, какие разделы нужно заполнить, какие данные указать и какие нюансы учесть.

ЕФС-1 при увольнении сотрудника: образец заполнения
Миникурсы, текстовые и видеоинструкции для бухгалтеров

Можно ли вернуть деньги за товар, если недостаки в нем выявлены спустя несколько лет

В основном недостатки в купленном товаре обнаруживаются в первые дни после покупки. И вопрос по поводу некачественного товара решается с продавцом достаточно быстро. А как быть, если недостатки были выявлены спустя несколько лет? Вот реальный пример из судебной практики.

Можно ли вернуть деньги за товар, если недостаки в нем выявлены спустя несколько лет

💥 Шесть вебинаров по налоговой реформе-2025: готовимся к новым НДФЛ, НДС, налогу на прибыль и УСН уже сейчас

С 2025 года все изменится, и половина НК будет переписана. Поэтому важно уже сейчас понять, какими будут новые правила игры и как организовать свою работу. «Клерк» проводит серию вебинаров с ведущими экспертами: налоговыми консультантами, юристами, адвокатами, аутсорсерами. Не пропустите!

💥 Шесть вебинаров по налоговой реформе-2025: готовимся к новым НДФЛ, НДС, налогу на прибыль и УСН уже сейчас
Санкции 2022-2024

Санкции США против НРД. Позиция EUROCLEAR

12 июня 2024 года США расширили санкционные списки в отношении российских субъектов. В числе прочих ограничения введены против Национального расчетного депозитария (НРД).

Санкции США против НРД. Позиция EUROCLEAR

За продажу детям энергетиков санкции будут, скорее всего, как за крепкий алкоголь

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

Из-за новых ставок по НДФЛ с 2025 года Госдума приняла поправки в федеральный бюджет

Изменения связаны в том числе с реформой в налоговой системе с 2025 года. Завтра депутаты рассмотрят еще три законопроекта из этого пакета.

Родителей уравняли в правах при получении документов в госорганах

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

Вакансии

Новые вакансии для бухгалтеров и финансистов Добавить вакансию

⚡️ Итоги дня: на Wildberries можно колеровать краску, «Вкусно — и точка» выплатила компенсацию пострадавшему в «Макдоналдсе», а Nvidia стала крупнейшей компанией в США

Подготовили обзор главных событий дня — 19 июня 2024 года. Все самое интересное, что писали и обсуждали в сети, в одной подборке.

Интересные материалы

Как систематизировать обучение в компании

В современном корпоративном обучении царит хаос: расписание — непредсказуемо, отчеты — заполняются вручную, аналитика — отсутствует. Это реальность, с которой сталкиваются многие компании. Однако, есть способы изменить ситуацию к лучшему.

Как систематизировать обучение в компании