Поиск, замена и удаление дубликатов (тонкий и толстый клиент)

24.03.14

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

Обработка работает на платформе 8.2. Имеет как обычную, так и управляемую форму. Предназначена для поиска дублирующихся объектов по установленным правилам сравнения, замены и последующей пометки на удаления и при необходимости полного удаления дубликатов.

Скачать файл

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

Наименование По подписке [?] Купить один файл
ПоискИУдалениеДубликатов.epf
.epf 58,30Kb
957
957 Скачать (1 SM) Купить за 1 850 руб.

Обработка постоена по типу помощника. На первой странице устанавливается объект метаданных с которым предполагается работать. Список ограничен справочниками и видами характеристик (может быть расширен как угодно раскоменнтированием пары строк в коде). Для принятия решения что на что менять можно настроить критерии определения заменяемых объектов (заполнение реквизитов не учитывает табличные части). Правила сравнения должны включать как минимум одно правило. Вид сравнения "Равенство" и "Содержит". Условие "Содержит" работает аналогично конструкции "Подобно" в запросе. Виды сравнения могут быть расширены раскомментированием строк в коде. Дополнительные сравнения на Владельца и ЭтоГруппа жестко вшито в код во избежании роковых ошибок. В отборе можно ограничить выборку проверяемых данных. На второй странице можно просмотреть и отредактировать (удалить или поменять местами) список дубликатов. На третьей странице можно просмотреть список объектов, в которых будет произведена замена. На этом этапе ещё можно отказаться от выполнения без обработки. На последней странице можно выбрать либо пометку на удаление либо полное удаление замененных объектов. Физическое удаление производится после контроля ссылочной целостности. Обработка не учитывает структуру базы данных, поэтому после удаления дубликатов надо проверить на дубликаты и подчиненные объекты метаданных (например, после удаления дубликатов контрагентов, надо проверить на дубликаты и договора контрагентов).

Внимание! Обработка производит массовую модификацию объектов баз данных и (при определенных настройках) полное удаление объектов.  Поэтому знакомство с обработкой рекомендуется проводить на копиях баз данных. Разработчик ответственности за потерянные данные не несет.

Обработка включает в себя модифицированные части кода из широко известных универсальных обработок 1С.

См. также

SALE! 15%

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

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

8400 7140 руб.

20.08.2024    8117    60    28    

71

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

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

3582 руб.

16.03.2015    173944    209    81    

244

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

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

9600 руб.

22.02.2013    138448    259    144    

430

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

Обработка позволяет удобно и выборочно удалить данные из базы 1С. Это могут быть как неиспользуемые элементы справочников, так и неактуальные организации. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся.

3350 руб.

28.11.2019    25890    59    16    

74

Оптовая торговля Логистика, склад и ТМЦ Чистка данных Программист Бухгалтер Пользователь Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 11 Россия Управленческий учет Платные (руб)

Если вы начали работать в программном продукте Управление Торговлей, редакция 11 или Комплексная Автоматизация редакция 2 и включили механизм учёта серий, то перейти обратно в учёт без серий будет не так-то просто. Сложность заключается в том, что нужно очистить серии в табличной части документа, например, Реализация Товаров и услуг. Предлагаем алгоритм перехода на учет без серий для программного продукта УТ11. (Очистка серий.)

2400 руб.

09.04.2019    29071    43    14    

45

Чистка данных Системный администратор Программист Бухгалтер Пользователь Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

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

3960 руб.

27.06.2018    19163    11    3    

16

Чистка данных Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Если в вашей информационной базе крутится очень много данных, или база должна быть доступна 24/7 (как в моем случае), или же вы боитесь запускать тестирование и исправление, НО существует потребность удалить битые ссылки, тогда эта обработка сможет Вам помочь. Обработка выявляет битые ссылки как в самих объектах метаданных, так и в их табличных частях(!), а так же может их удалить.

2400 руб.

23.08.2021    9950    19    3    

25

Чистка данных Системный администратор Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

1 стартмани

21.01.2022    7714    1    dmbal    6    

12
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. makas 44 19.09.12 11:19 Сейчас в теме
Полезная штука. судя по описанию!
2. students 26.09.12 09:36 Сейчас в теме
Привет. Данная обработка может менять ссылки у подчиненных объектов как стандартная из УПП. Например (Контрагент - договора)
3. Kobra_RU 245 26.09.12 15:49 Сейчас в теме
(2) students,
Это вопрос? Я стандартные обработки как в УПП так и в других типовых конфигурациях не использую во избежании (был опыт использования встроенной обработки перепроведения документов).
Эта обработка не учитывает подчинение, т.к. не знает структуру конфигурации. Если мы делаем из 2 контрагентов одного, то результатом будет 1 контрагент с 2 договорами контрагентов (в простейшем случае) от первого и от второго контрагента по одному. Поэтому после этой операции надо чистить и договора контрагентов со сравнением на равенство организации и вида договора, например, или ещё по наименованию (если договоры учтены по номерам и т.п.).Аналогично, номенклатура и единицы измерения номенклатуры (в торговле и УПП) и т.п. А вообще попробуйте на копии базы и все сами увидите...
4. ds_square 07.12.12 09:44 Сейчас в теме
Отличная штука!Правда, каждый раз пользуюсь и боязно при большом кол-ве номенклатуры...
5. sorb 03.04.13 08:41 Сейчас в теме
Единственная адекватная замена типовой обработке "Поиск и замена дублирующихся элементов справочников" под УФ. Автору плюс и спасибо.
6. prodines 107 06.05.13 13:09 Сейчас в теме
Нет возможности вести поиск по владельцу - для тех же договоров контрагента.
7. Kobra_RU 245 06.05.13 15:43 Сейчас в теме
При поиске дубликатов владелец учитывается автоматически. То есть, если мы ведем поиск по совпадению наименований договоров, например, то в качестве дубликатов будут отобраны только те договора, в которых совпадает и наименование и владелец договора. Этот дополнительный элемент поиска жестко встроен в код во избежании фатальных невосстановимых изменений данных (например, замены во всех документах единицы измерения лишь одной номенклатуры).
8. kuza_87 28 08.08.13 07:34 Сейчас в теме
Автору большое спасибо, для управляемых форм больше ничего не нашел, а самому писать было лень
9. nmgmex 09.08.13 09:44 Сейчас в теме
потестируем) автору плюс
10. kuza_87 28 09.08.13 11:12 Сейчас в теме
Дубли на удаление нормально помечает, но не удаляет. Что сделать чтобы удалить дубли?
11. Kobra_RU 245 12.08.13 09:34 Сейчас в теме
Самое простое - не установлен флажок "Удалить замененные объекты с контролем ссылочной целостности".
А вообще различных вариантов может быть много. Например, у пользователя нет прав на удаление объектов.
Если объекты удаляются, но не все, надо запустить поиск ссылок и проверить не остались ли ещё не замененные реквизиты. Такие случаи могут быть вызваны особенностями конкретной конфигурации.
12. kuza_87 28 12.08.13 09:43 Сейчас в теме
(11) самое интересное что в тонком клиенте ссылки не удаляются, а в толстом под этим же пользователем с такими же правами удаляются.
13. Kobra_RU 245 12.08.13 12:41 Сейчас в теме
Проверил ещё раз на базе (файловый вариант). Все вроде бы работает нормально.
Обработка полностью открытая, поэтому советую Вам посмотреть в отладчике, в чем там проблема. Код там несложный и понятный, можно сделать выводы даже в серверном варианте без отладочного режима (функция УдалитьОбъектыНаКлиенте()). Если этим займетесь, сообщите о конкретной обнаруженной проблеме - исправлю...
14. BTRVODKA 10 15.09.13 04:43 Сейчас в теме
Спасибо автору за публикацию!
15. Aleksand1985 7 14.11.13 10:08 Сейчас в теме
Стартмани сняли, а файл не скачал! Обидно!
16. krolikofff 21.03.14 17:40 Сейчас в теме
Имеется файловая база, БП 2.0 (2.0.56.2), толстый клиент. На этапе "замена ссылок на дубликаты" возникает ошибка - Индекс находится за границами массива

{Форма.ФормаТК.Форма(1105)}: Индекс находится за границами массива
						Если Измерение.Тип.СодержитТип(ТипЗнч(Ссылка)) И НаборЗаписи[0][Измерение.Имя]=Ссылка Тогда


Как быть?
17. Kobra_RU 245 24.03.14 08:34 Сейчас в теме
Скорректировал в обработке код.
Вы можете исправить у себя:
						Для Каждого Измерение ИЗ Последовательность.Измерения Цикл
							Если Измерение.Тип.СодержитТип(ТипЗнч(Ссылка)) И НаборЗаписи[0][Измерение.Имя]=Ссылка Тогда
								НаборЗаписи[0][Измерение.Имя] = ПравильныйЭлемент;
								НадоЗаписывать = Истина;
							КонецЕсли;
						КонецЦикла;


на
					Если НаборЗаписи.Количество() > 0 Тогда
						Для Каждого Измерение ИЗ Последовательность.Измерения Цикл
							Если Измерение.Тип.СодержитТип(ТипЗнч(Ссылка)) И НаборЗаписи[0][Измерение.Имя]=Ссылка Тогда
								НаборЗаписи[0][Измерение.Имя] = ПравильныйЭлемент;
								НадоЗаписывать = Истина;
							КонецЕсли;
						КонецЦикла;
					КонецЕсли;
Показать
lamaker9876; ollega; Stranger777; Kesak; +4 Ответить
18. krolikofff 24.03.14 11:07 Сейчас в теме
19. sobeyko2008 17 26.03.14 21:21 Сейчас в теме
А как галочки поставить на то что я хочу удалить. Или удалять обязательно все объекты которые нашла обработка? А если я так не хочу?))
20. Kobra_RU 245 27.03.14 09:02 Сейчас в теме
Эта обработка задумана как технологический инструмент для быстрого и окончательного сноса дубликатов, возникших, например, при ошибках в схемах конвертации данных. Практически все видели, например, две валюты "рубли" с разными кодами. Если же есть желание оставить дубликаты, их можно только пометить на удаление, потом с помощью обработки "Удаление помеченных объектов" удалить, то что необходимо удалить, с остальных пометку снять. И, конечно, Вы можете доработать эту обработку.
21. Ifboop_Figure 63 17.04.14 16:34 Сейчас в теме
Отличная обработка. Спасибо!
22. @Sonya 27 02.06.14 10:09 Сейчас в теме
Очень нужная обработка, спасибо! Было бы супер, если бы функция Поменять местами работала для всех выделенных строк!
23. artfa 58 06.02.15 16:53 Сейчас в теме
годная обработка,
но в УТ 10.3 и РТ 1.0 ни в какую не захотела удалять одну и ту же (обмен УТ<>РТ), позицию номенклатуры, пришлось удалить непосредственно,

Оставьте свое сообщение