Замена ссылочных значений во всей базе данных 1С 8.2, 8.3 (управляемые формы)

16.02.19

База данных - Чистка данных

Обработка для замены любых ссылочных значений во всей БД для возможности последующего удаления замененных объектов по необходимости.

Файлы

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

Наименование Скачано Купить файл
Замена ссылочных значений во всей базе данных 1С 8.2, 8.3 (Управляемые Формы):
.epf 17,10Kb
49 2 150 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Приветствую, коллеги!

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

Итак, приступим. 

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

Почему именно дерево, а не таблица? Потому что до сих пор существуют справочники, подчиненные друг другу. Например, договоры подчинены контрагентам. В этом случае для замены договора будет необходимо создать узел с контрагентом, после чего создать подчиненный узел для замены договоров. При этом если мы планируем заменить только договор, оставив контрагента без изменений, то флажок "Заменять" на узле контрагента необходимо снять. Именно этот случай и продемонстрирован на первом скриншоте. Поэтому для добавления в дерево существуют две кнопки "Добавить корневой" и "Добавить". Первая добавит новый узел в корень дерева, а вторая - под текущий узел, на котором стоит курсор. Чаще всего моя работа с обработкой ограничивается добавлением нескольких позиций в корень и их последующей заменой. Следует отметить, что в процессе замены иерархия дерева не имеет никакого значения - это лишь интерфейсная особенность для выбора элементов подчиненных объектов.

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

После заполнения дерева можно посмотреть масштаб предстоящих замен при помощи кнопки "Просмотреть связи" - будет показана таблица как на втором скриншоте. Если все устраивает, можно нажать "Выполнить замену" и ожидать результата. По окончании обработка ничего не выводит - просто отвисает. Замена выполняется клиентом на сервере (то есть не в фоне - юзер может убить процесс 1С, если понял, что совершил ошибку).

 

Это что касалось разового ручного использования. А что же делать, если нам требуется замена тонны каких-либо ссылок на другие и это вычисляется каким-либо алгоритмом? Тут два пути. Первый - это найти похожую обработку на Инфостарте по поисковой строке "поиск и замена значений", освоить ее, и при достаточной ее универсальности реализовать задуманное без программного вмешательства. К счастью, мои задачи требуют более глубокого анализа данных, и не решаются подобными обработками. Поэтому второй путь - это взять данную обработку за основу (скопипастить), назвать в стиле "Замена значений - одноразовая для Васи Пупкина чтобы заменить то да сё.epf". А дальше все просто: на форму кидаем кнопку, на нее вешаем серверный алгоритм и по результату закидываем линейно в корень дерева необходимые нам данные. Требуется заполнять только три колонки: флаг "заменять", ссылку старую и ссылку новую. А далее все как и при разовой ручной замене - можно посмотреть связи, а можно сразу приступить к замене. 

Обработка не влияет на бухгалтерские итоги, да и вообще на любые другие итоги, так как не отключает их пересчет. Опытным путем было выяснено, что временное отключение пересчета итогов и последующее включение с пересчетом лишь замедляют процесс замены в общем случае, а также не способствуют работе пользователей в базе. Также следует отметить, что алгоритм достаточно оптимален, используются быстрые методы из возможных и последующие попытки оптимизации могут закончиться ошибками в регистрах. Я уже так натыкался, по глупости использовав ОбменДанными.Загрузка = Истина для регистра бухгалтерии, после чего приходилось выполнять ТИИ.

 

С осторожностью:

-- В базах данных, где у справочников есть  общие реквизиты - их замена не предусмотрена (именно в справочниках)

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

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

 

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

Приятного использования.

Вступайте в нашу телеграмм-группу Инфостарт

Замена значения Загрузка Конфигурация такси УФ управляемая форма дерево обработка подмена справочников документов ссылок

См. также

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

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

8400 руб.

20.08.2024    40981    223    115    

212

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

Данные обработки помогут Вам легко и, главное быстро, выполнить удаление любых данных в Ваших базах 1С на платформах 8.1-8.3. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 27.08.2025, версия 4.4)

10800 руб.

22.02.2013    142194    280    147    

448

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

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

3600 руб.

10.02.2017    115807    697    176    

738

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

Позволяет удалить организации из любых из информационных баз 1С на управляемых формах (БП 3.0, УТ 11, КА 2, ERP 2, ЗУП 3.0, УНФ, Розница 2.0 и пр.). Главное требование - программа должна содержать справочник "Организации". Реализован самый быстрый алгоритм непосредственного удаления объектов. Работает даже на базах большого размера. Для ускорения работы алгоритма не запускается проверка контроля ссылочной целостности. Проверку учета можно запустить отдельно с помощью дополнительной обработки. Необходимо перед удалением самостоятельно проверить базу на наличие перекрестных ссылок разных организаций в одном документе. Эту дополнительную обработку проверки перекрестных ссылок по запросу предоставляем бесплатно нашим покупателям.

5160 руб.

16.03.2015    253026    234    83    

270

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

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

14400 руб.

29.04.2020    39166    115    152    

82

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

Обработка позволяет удобно и выборочно удалить данные из базы 1С на управляемых формах например БП 3.0, УТ 11, КА 2, ERP, УНФ, ЗУП 3, Розница и др. Это могут быть неактуальные организации или другие перечни объектов. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся. Объекты нужно выбирать вручную и после этого запускать команду удаления. Будут удалены все ссылки на них.

5000 руб.

28.11.2019    28326    76    20    

91

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

Данные обработки помогут Вам быстро и просто выполнить перезапись любых ссылочных объектов, а также провести/снять с проведения документы с возможностью выбора регистров и произвольными отборами, в Ваших базах 1С на платформах 8.1-8.3. Обработка позволят найти документы с движениями или без них. Все это дает Вам мощный инструмент для работы. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. А также обновления Вы получаете бесплатно в течение года с момента приобретения данных обработок! Данные обработки входят в ТОП-100 продаж, что является залогом популярности, надежности в работе, и признанием других покупателей.

7200 руб.

17.09.2013    806280    58    51    

94

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

Вы наконец разобрались с закрытием месяцев и пора начать контролировать сроки оплаты поставщикам и задолженности клиентов, но в базе расчеты не идут из-за развернутого сальдо? Не беда, есть решение!

12000 руб.

02.11.2020    8405    6    3    

9
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. HOLIV 23.10.21 19:59 Сейчас в теме
2. Euroset1 12 22.06.23 18:23 Сейчас в теме
(1) Да скачивают люди раз в месяц в среднем. Я вот регулярно ей пользуюсь.
Для отправки сообщения требуется регистрация/авторизация