Ликвидация бизнеса. Приказы. Оборудование для бизнеса. Бухгалтерия и кадры
Поиск по сайту

1c 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.

В этом примере регистр Вклады имеет измерения: Клиент, ВидВклада, Отделение и ресурс СуммаВклада.

Чтобы просмотреть, какие движения сделал документ, нужно разместить курсор на документ в журнале документов и в меню Действия выбрать пункт Движения документа . Откроется список регистров, в котором флажками отмечены те, по которым есть движения. Выбрав интересующий регистр, мы увидим окно с движениями (рис. 2.4).

Рисунок 2.4 Движения документа

Получение итогов по регистру.

Получение остатков (только для регистров остатков).

Метод Остаток(<Измерен1>, <Измерен2>, …, <ИмяРесурса>) – позволяет получить текущий остаток указанного ресурса по совокупности измерений. Пример: получение остатка средств на счету клиента банка (рис. 2.5):

Рисунок 2.5 Пример использования метода Остаток

Метод СводныйОстаток (<Измерен1>, <Измерен2>, …, <ИмяРесурса>) – некоторые значения измерений могут быть опущены. Пример: получение остатка средств на всех счетах клиента банка (рис. 2.6):

Рисунок 2.6 Пример использования метода СводныйОстаток

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

Метод Итог(<Измерен1>, <Измерен2>, …, <ИмяРесурса>) позволяет получить оборот за период по заданной совокупности измерений. Пример: получение оборотов по счету клиента банка (рис. 2.7):

Рисунок 2.7 Пример использования метода Итог

Метод СводныйИтог(<Измерен1>, <Измерен2>, …, <ИмяРесурса>) - некоторые значения измерений могут быть опущены. Пример: получение оборотов по всем счетам за день (установленная периодичность регистра) (рис. 2.8):

Рисунок 2.8 Пример использования метода СводныйИтог

3. Задания.

1. Создайте новую конфигурацию.

2. Создайте справочники "Товары", "Склады", "Контрагенты".

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

4. Создайте регистр остатков ОстаткиТоваров с измерениями Товар, Склад и ресурсами Количество, Сумма.

5. Создайте оборотный регистр Продажи с измерениями Контрагент, Товар и ресурсами Количество, Сумма. Периодичность - месяц.

6. Сохраните конфигурацию и посмотрите структуру файлов регистров в файле 1cv7.dd.

7. Создайте документ «ПоступлениеТоваров» с реквизитами шапки «Контрагент» (тип Справочник.Контрагенты), «Склад» (тип Справочник.Склады) и реквизитами табличной части «Товар» (тип Справочник.Товары), «Цена», «Количество», «Сумма» (все тип Число). При проведении документа должна выполняться запись движений прихода по регистру ОстаткиТоваров.

8. Создайте документ «Реализация» с реквизитами шапки «Контрагент» (тип Справочник.Контрагенты), «Склад» (тип Справочник.Склады) и реквизитами табличной части «Товар» (тип Справочник.Товары), «Цена», «Количество», «Сумма» (все тип Число). При вводе количества должна выполняться проверка превышения вводимого количества над имеющимся на складе. При проведении документа должна выполняться запись движений по регистру Продажи.

9. Чтобы установить точку актуальности итогов, выберите пункт меню «Операции» – «Управление оперативными итогами» в режиме использования 1С. Чтобы эта команда была доступна, закройте все окна.

10. Добавьте проведение документа «Реализация» по регистру ОстаткиТоваров. Проверьте корректность проведения документа, вводя документы оперативно и «задним числом».

11. Разработайте документ «ПеремещениеТоваров», который выполняет перемещение товара с одного склада на другой, напишите процедуру проведения этого документа по регистру ОстаткиТоваров.

12. Напишите отчеты по остаткам и оборотам товаров.

4. Контрольные вопросы.

1. Каково назначение компоненты «Оперативный учет»?

2. Какие виды объектов метаданных доступны для конфигурирования в компоненте «Оперативный учет»?

3. Как в программе хранятся итоги? Каково назначение системы регистров?

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

5. Какие данные и когда записываются в регистры?

6. В чем отличие регистров остатков от оборотных регистров?

7. Как можно построить выборку по движениям регистров? Как использовать значения реквизитов регистра для ограничения такой выборки?

8. Что такое измерения, ресурсы и реквизиты регистра? Какие типы данных могут использоваться для их описания?

9. В чем отличие методов получения итогов по оборотным регистрам от методов получения остатков по регистрам остатков?

10. Что такое «временный расчет»? когда его необходимо использовать? Какие методы встроенного языка для организации временного расчета вы знаете?

1. 1С:Предприятие 7.7. Описание встроенного языка.

2. Митичкин С.А. Электронное учебное пособие «Практика программирования в среде 1С:Предприятие».

3. Рязанцев Н., Рязанцев Д. 1С: Предприятие. Секреты программирования.- СПб.: БХВ – Петербург, 2004 – 352 с.

4. Усиков Т.Н. 1С: Предприятие. Эффективное программирование – М.: Новое знание, 2004 – 446 с.

5. Бартеньев О.В. 1С:Предприятие: программирование для всех. Базовые объекты и расчёты на одной дискете – М.:Диалог-МИФИ, 2004. – 464с.

6. Михайлов С.Е. 1С-программирование как дважды два. Самоучитель.-СПб.:Тритон, 2005.-173, с.:ил.

7. www.1C.ru – официальный сайт компании 1С.

8. www.mista.ru – программирование в системе 1С:Предприятие.

9. www.m2bc.ru – консультации по ведению учета и программированию в системе 1С:Предприятие.

10. http://www.vitalikk.ru/html/book/book-1c-000.html - учебник.


Составитель

Смирнова Мария Николаевна

РАБОТА С ОБЪЕКТАМИ КОМПОНЕНТЫ
«ОПЕРАТИВНЫЙ УЧЕТ» НА ВСТРОЕННОМ ЯЗЫКЕ СИСТЕМЫ 1С:ПРЕДПРИЯТИЕ 7.7

Методические указания к лабораторной работе №10
по курсу «Компьютерные технологии финансовых операций»
для студентов специальности 351400 (080801)
«Прикладная информатика в экономике»

Подписано в печать.

Формат 60×84/16. Бумага офсетная. Отпечатано на ризографе.

Уч.-изд. л. 0,7. Тираж 100 экз. Заказ

ГУ КузГТУ. 650026, Кемерово, ул. Весенняя, 28.

Типография ГУ КузГТУ, 650099, Кемерово, ул. Д. Бедного, 4а.