"Мягкое" перепроведение документов

24.01.20

База данных - Инструменты администратора БД

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Мягкое перепроведение документов:
.epf 9,57Kb ver:1.0.0
50
50 Скачать (1 SM) Купить за 1 850 руб.

В каких случаях это пригодится:

  • Массовое исправление существующих движений после обнаружения ошибки.
  • Исправление движений в закрытом периоде.
  • Заполнение движениями нового пустого регистра.
  • Проведение документа, проведение которого из интерфейса невозможно.
  • Перепроведение документов после изменения одного из параметров учета.

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

  1. Начинаем транзакцию
  2. Проводим документ
  3. Сохраняем нужные движения во временную таблицу
  4. Отменяем транзакцию
  5. Помещаем движения из временной таблицы в регистр.

Однако, у этого метода есть недостатки.

Во-первых, поскольку требуется проведение документа, срабатывают все процедуры с этим связанные. Проверка заполнения, подписки на события и т.п. Следовательно, это очень замедляет проведение. Особенно если это старая база и документов несколько сотен тысяч.

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

Способ, который я предлагаю, основан на типовом алгоритме проведения, принятом в большинстве "больших" документов типовых конфигураций. По крайней мере документов УТ и ERP, почти наверняка КА и УХ и, вероятно, БП. Если вы внимательно изучите их модули объектов и обратите внимание на проведение, то заметите сходство. Это сходство я и предлагаю использовать. В общем виде алгоритм выглядит так:

  1. Инициализация таблиц для движений
  2. Заполнение их с использованием менеджера документа
  3. Помещение движений в регистры

И его реализация в виде кода:

ТипДокумента = "ЗаказКлиента";
Документ = Документы[ТипДокумента].НайтиПоНомеру("0000-000001", ТекущаяДатаСеанса());

МенеджерРегистров = РегистрыНакопления;
ИмяРегистра = "РасчетыСКлиентами";

ОбменДаннымиЗагрузка = Истина;

ДокОбъект = Документ.ПолучитьОбъект();

//	Инициализация дополнительных свойств
ПроведениеСерверУТ.ИнициализироватьДополнительныеСвойстваДляПроведения(Документ, ДокОбъект.ДополнительныеСвойства, РежимПроведенияДокумента.Неоперативный);

//	Выполнение запросов и получение данных о движениях
Документы[ТипДокумента].ИнициализироватьДанныеДокумента(Документ, ДокОбъект.ДополнительныеСвойства);

Если Не ДокОбъект.ДополнительныеСвойства.ТаблицыДляДвижений.Свойство("Таблица" + ИмяРегистра) Тогда
	Сообщить("Регистр " + ИмяРегистра + " пропущен. Движения по нему не формируются при проведении документа.");
	Возврат;
КонецЕсли;

Таблица = ДокОбъект.ДополнительныеСвойства.ТаблицыДляДвижений["Таблица" + ИмяРегистра];

НаборЗаписей = МенеджерРегистров[ИмяРегистра].СоздатьНаборЗаписей();
НаборЗаписей.Отбор.Регистратор.Установить(ДокОбъект.Ссылка);
НаборЗаписей.Загрузить(Таблица);

НаборЗаписей.ОбменДанными.Загрузка = ОбменДаннымиЗагрузка;

НаборЗаписей.Записать();

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

Тестировалось на платформе 8.3.15.1565 и конфигурации 1С:ERP 2.4.10.89.

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

См. также

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14970    109    46    

108

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

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

15000 руб.

10.11.2023    12015    45    33    

67

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 18.09.2024, версия 1.2

18000 руб.

06.12.2023    10874    47    8    

78

SALE! %

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

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

4800 3840 руб.

14.01.2013    191535    1153    0    

920

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

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

14400 руб.

29.04.2020    33919    108    152    

75

Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Брандмауэр для сервера 1С включает в себя управление возможностью начала и возобновления сеансов пользователей по различным условиям, ограничение общего числа возможных сеансов для работы с информационной базой, резервирование возможности работы с информационной базой определенных польззователей, запрет запуска нескольких сеансов для пользователя, журнализация событий начала (возобновления) и завершения (гибернации) сеансов, ведение списка активных сеансов для информационных баз кластера серверов

3600 руб.

06.02.2017    32721    145    18    

51

Архивирование (backup) Инструменты администратора БД Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    73829    629    45    

88

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

Многие сталкиваются с проблемой когда изображения, находящиеся в базе разные по объему и размерам. Менеджеры могут добавить файлы в очень высоком разрешении, объемом свыше 20 Мегабайт. База данных становится слишком большой, выгрузка на сайт идёт медленно и требуется много место на хостинге. Как сжать картинки и уменьшить размер базы 1С? Это можно сделать с помощью данной обработки. Существует возможность выбрать различные варианты для того чтобы уменьшить картинки: в разы, в процентах от первоначального объема, а также сделать картинки одинаковой ширины. В результате размер базы 1С значительно сократится (в зависимости от количества и размера картинок), а изображения станут небольшого объема, равными по ширине, почти без потери качества. Работает на управляемых формах для УТ 11, КА, ERP.

3000 руб.

21.07.2022    10206    10    4    

18
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mm_84 24.01.20 12:54 Сейчас в теме
В типовых конфигурациях это делается через подсистему "обновление версий ИБ". И не факт что вышеописанный метод не споткнется на проверке даты запрета редактирования.
2. DrAku1a 1750 06.02.20 18:03 Сейчас в теме
(1) Если ОбменДаннымиЗагрузка будет Истина, то не споткнется.

В старых конфигурациях делал такой "финт ушами" (метод подойдёт везде, но нужно сразу что-то решать с датой запрета):
1.Начать транзакцию
2.Записать документ в режиме проведения
3.Выгрузить нужный регистр в таблицу значений
4.Отменить транзакцию
5.Зарисать нужный регистр из таблицы значений
3. nekit_rdx 222 07.02.20 12:07 Сейчас в теме
(2) Это, кстати, крутой универсальный способ. Причем даже в типовых конфигурациях для некоторых документов только он и пройдет. Но работает медленно
Оставьте свое сообщение