Очистка данных в ИБ по выбранным организациям (удаление выбранных организаций из ИБ)

25.11.15

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

Обработка предназначена для пометки на удаление данных (справочников, документов и т.п.), связанных с выбранными организациями.

Файлы

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

Наименование Скачано Купить файл
UdalenieOrganizatsiyIzIB.epf.7z
.7z 6,15Kb
89 2 500 руб. Купить

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

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

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

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

Появилась задача удалить из базы УПП ненужные (отработавшие своё) организации. Написал обработку. Может, кому пригодится (полностью или частями).

Разрабатывалось для УПП, ред. 1.3 (1.3.62), но, скорее всего, может быть использовано и на других конфигурациях (возможно, потребуются необольшие переделки).

Алгоритм работы:

  1. Помечаем на удаление выбранную организацию и очищаем у неё реквизит ОсновнойБанковскийСчет.
  2. У контрагентов, чей основной договор принадлежит удаляемой организации, очищаем реквизит ОсновнойДоговорКонтрагента.
  3. Очищаем наборы регистров сведений, у которых есть измерение Организация и оно не отмечено как Ведущее, с отбором по удаляемой организации.
  4. Очищаем наборы регистров сведений, у которых есть измерение ПодразделениеОрганизации и оно не отмечено как Ведущее, с отбором по "Владелец подразделения организации = удаляемая организации".
  5. Ищем по ссылкам на удаляемую организацию (через НайтиПоСсылкам) справочники, документы, бизнес-процессы и задачи. Всё найденное помечаем на удаление.

Для изготовления данной обработки в домашних условиях необходимо:

  1. Создать новую обработку и неуправляемую форму для неё.
  2. На форму обработки добавить Поле списка с пометками (тип = Список значений, имя = СписокУдаляемыхОрганизаций) и командную панель КоманднаяПанель1 с одной кнопкой ОбновитьСписок (см. скриншот в шапке статьи).
  3. Добавить в модуль формы исходный текст (GPLv3), связать события элементов формы с обработчиками (КнопкаВыполнитьНажатие/КоманднаяПанель1ОбновитьСписок/ПриОткрытии/СписокУдаляемыхОрганизацийВыбор):
Процедура ОчиститьОсновныеДоговорыПоОрганизации(ПарамОрганизация)
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	Контрагенты.Ссылка,
	|	Контрагенты.Представление
	|ИЗ
	|	Справочник.Контрагенты КАК Контрагенты
	|ГДЕ
	|	Контрагенты.ОсновнойДоговорКонтрагента.Организация = &Организация";
	Запрос.УстановитьПараметр("Организация", ПарамОрганизация);
	
	РезультатЗапроса = Запрос.Выполнить();
	Если РезультатЗапроса.Пустой() Тогда
		Возврат;
	КонецЕсли;
	
	Выборка = РезультатЗапроса.Выбрать();
	Пока Выборка.Следующий() Цикл
		Состояние("Очистка осн.дог. у " + Выборка.Представление);
		СпрОбъект = Выборка.Ссылка.ПолучитьОбъект();
		СпрОбъект.ОсновнойДоговорКонтрагента = Справочники.ДоговорыКонтрагентов.ПустаяСсылка();
		СпрОбъект.Записать();
	КонецЦикла; 
	
КонецПроцедуры

Процедура ОчиститьРегистрыСведенийПоОрганизации(ПарамОрганизация)
	
	РегистрыДляОчистки = Новый Структура; // ключ - имя рег.сведений, значение - измерение, в котором указана организация
	РегистрыДляОчистки.Вставить("КонтактнаяИнформация", "Объект");

	Для Каждого МетаРег Из Метаданные.РегистрыСведений Цикл
		Если МетаРег.РежимЗаписи = Метаданные.СвойстваОбъектов.РежимЗаписиРегистра.Независимый Тогда
			РеквОрг = МетаРег.Измерения.Найти("Организация");
			Если РеквОрг <> Неопределено
				И (НЕ РеквОрг.Ведущее)
				И РеквОрг.Тип.СодержитТип(ТипЗнч(ПарамОрганизация)) Тогда
				РегистрыДляОчистки.Вставить(МетаРег.Имя, "Организация");
			КонецЕсли; 
		КонецЕсли; 
	КонецЦикла; 
	
	Для Каждого КлючИЗначение Из РегистрыДляОчистки Цикл
		ИмяРегистра = КлючИЗначение.Ключ;
		ИмяИзмерения = КлючИЗначение.Значение;
		Состояние("Очистка р/с " + ИмяРегистра);
		НаборЗаписей = РегистрыСведений[ИмяРегистра].СоздатьНаборЗаписей();
		ОтборПоОрганизации = НаборЗаписей.Отбор.Найти(ИмяИзмерения);
		ОтборПоОрганизации.Установить(ПарамОрганизация);
		НаборЗаписей.Очистить();
		НаборЗаписей.Записать();
	КонецЦикла; 
	
КонецПроцедуры

Процедура ОчиститьРегистрыСведенийПоПодразделенениямОрганизации(ПарамОрганизация)
	
	РегистрыДляОчистки = Новый Структура; // ключ - имя рег.сведений, значение - измерение, в котором указана организация

	Для Каждого МетаРег Из Метаданные.РегистрыСведений Цикл
		Если МетаРег.РежимЗаписи = Метаданные.СвойстваОбъектов.РежимЗаписиРегистра.Независимый Тогда
			РеквПодразд = МетаРег.Измерения.Найти("ПодразделениеОрганизации");
			Если РеквПодразд <> Неопределено
				И (НЕ РеквПодразд.Ведущее)
				И РеквПодразд.Тип.СодержитТип(Тип("СправочникСсылка.ПодразделенияОрганизаций")) Тогда
				РегистрыДляОчистки.Вставить(МетаРег.Имя, "ПодразделениеОрганизации");
			КонецЕсли; 
		КонецЕсли; 
	КонецЦикла; 
	
	Для Каждого КлючИЗначение Из РегистрыДляОчистки Цикл
		ИмяРегистра = КлючИЗначение.Ключ;
		ИмяИзмерения = КлючИЗначение.Значение;
		Состояние("Очистка р/с " + ИмяРегистра);
		Запрос = Новый Запрос;
		Запрос.Текст = 
		"ВЫБРАТЬ РАЗЛИЧНЫЕ
		|	ПодразделениеОрганизации
		|ИЗ
		|	РегистрСведений.ШтатноеРасписаниеОрганизаций
		|ГДЕ
		|	ПодразделениеОрганизации.Владелец = &Организация";
		Запрос.Текст = СтрЗаменить(Запрос.Текст, "ШтатноеРасписаниеОрганизаций", ИмяРегистра);
		Запрос.УстановитьПараметр("Организация", ПарамОрганизация);
		РезультатЗапроса = Запрос.Выполнить();
		Если РезультатЗапроса.Пустой() Тогда
			Продолжить;
		КонецЕсли; 
		Выборка = РезультатЗапроса.Выбрать();
		Пока Выборка.Следующий() Цикл
			НаборЗаписей = РегистрыСведений[ИмяРегистра].СоздатьНаборЗаписей();
			ОтборПоОрганизации = НаборЗаписей.Отбор.Найти(ИмяИзмерения);
			ОтборПоОрганизации.Установить(Выборка.ПодразделениеОрганизации);
			НаборЗаписей.Очистить();
			НаборЗаписей.Записать();
		КонецЦикла; 
	КонецЦикла; 
	
КонецПроцедуры

Процедура ОчиститьДанныеПоОрганизации(ПарамОрганизация)
	
	Состояние("Поиск ссылок на " + ПарамОрганизация);
	
	МассивОрганизаций = Новый Массив;
	МассивОрганизаций.Добавить(ПарамОрганизация);
	ТЗ = НайтиПоСсылкам(МассивОрганизаций);
	
	Если ТЗ.Количество() = 0 Тогда
		Состояние("ССЫЛОК БОЛЬШЕ НЕТ!");
		Возврат;
	КонецЕсли; 
	
	МассивНеудаленных = Новый Массив; 
	
	КолвоВсего = ТЗ.Количество();
	КолвоОбработано = 0;
	Шаг = Цел(КолвоВсего / 100);
	Если Шаг = 0 Тогда
		Шаг = 1;
	КонецЕсли; 
	
	
	Для Каждого СтрокаТЗ Из ТЗ Цикл
		Если Цел(КолвоОбработано / Шаг) = (КолвоОбработано / Шаг) Тогда
			Состояние("" + ПарамОрганизация + ": " + Формат(КолвоОбработано / КолвоВсего * 100, "ЧДЦ=0; ЧН=") + "%")
		КонецЕсли; 

		НайденнаяСсылка = СтрокаТЗ[1];
		ТипНайденнойСсылки = ТипЗнч(НайденнаяСсылка);
		Если ЗначениеЗаполнено(НайденнаяСсылка) 
			И (Справочники.ТипВсеСсылки().СодержитТип(ТипНайденнойСсылки)
				ИЛИ Документы.ТипВсеСсылки().СодержитТип(ТипНайденнойСсылки)
				ИЛИ БизнесПроцессы.ТипВсеСсылки().СодержитТип(ТипНайденнойСсылки)
				ИЛИ Задачи.ТипВсеСсылки().СодержитТип(ТипНайденнойСсылки)) Тогда
				
			// { доп.проверка на реквизит Организация
			Если Документы.ТипВсеСсылки().СодержитТип(ТипНайденнойСсылки) Тогда
				МетаДок = НайденнаяСсылка.Метаданные();
				РеквОрг = МетаДок.Реквизиты.Найти("Организация");
				Если РеквОрг <> Неопределено
					И РеквОрг.Тип.СодержитТип(ТипЗнч(ПарамОрганизация))
					И НайденнаяСсылка.Организация <> ПарамОрганизация Тогда
					ВызватьИсключение "Документ " + НайденнаяСсылка + " относится к организации " + НайденнаяСсылка.Организация + ", но найден по ссылкам на организацию " + ПарамОрганизация;
					Возврат;
				КонецЕсли; 
			КонецЕсли;
			// доп.проверка на реквизит Организация }
			
			Попытка
				ТекОбъект = НайденнаяСсылка.ПолучитьОбъект();
				ТекОбъект.УстановитьПометкуУдаления(Истина);
			Исключение
				Сообщить("Ошибка удаления " + НайденнаяСсылка + ": " + ОписаниеОшибки());
				МассивНеудаленных.Добавить(СтрокаТЗ);	
			КонецПопытки;
			
		Иначе 
			МассивНеудаленных.Добавить(СтрокаТЗ);
		КонецЕсли; 
		
		КолвоОбработано = КолвоОбработано + 1; 
		
	КонецЦикла; 
	
	Для Каждого СтрокаТЗ Из МассивНеудаленных Цикл
		Сообщить("Не удалено: " + СтрокаТЗ[1] + " (" + СтрокаТЗ[2] + ")");
	КонецЦикла; 
	
КонецПроцедуры

Процедура КнопкаВыполнитьНажатие(Кнопка)
	
	ВыбранныеОрганизации = Новый Массив;
	Для Каждого ЭлементСписка Из СписокУдаляемыхОрганизаций Цикл
		Если ЭлементСписка.Пометка Тогда
			ВыбранныеОрганизации.Добавить(ЭлементСписка.Значение);
		КонецЕсли; 
	КонецЦикла; 
	
	КолвоВыбрано = ВыбранныеОрганизации.Количество();
	ТекстВопроса = ?(КолвоВыбрано = 1, 
					"Вы уверены что хотите удалить организацию " + ВыбранныеОрганизации[0] + "?",
					"Вы уверены что хотите удалить выбранные организации (" + КолвоВыбрано + " шт.)?");
	
	Ответ = Вопрос(ТекстВопроса, РежимДиалогаВопрос.ДаНетОтмена);
	Если Ответ <> КодВозвратаДиалога.Да Тогда
		Возврат;
	КонецЕсли;  
	
	Для Каждого УдаляемаяОрганизация Из ВыбранныеОрганизации Цикл
		
		СпрОбъект = УдаляемаяОрганизация.ПолучитьОбъект();
		Если НЕ СпрОбъект.ПометкаУдаления Тогда
			СпрОбъект.УстановитьПометкуУдаления(Истина);
		КонецЕсли;
		Если ЗначениеЗаполнено(СпрОбъект.ОсновнойБанковскийСчет) Тогда
			СпрОбъект.ОсновнойБанковскийСчет = Справочники.БанковскиеСчета.ПустаяСсылка();
		КонецЕсли; 
		Если СпрОбъект.Модифицированность() Тогда
			СпрОбъект.Записать();
		КонецЕсли; 
		
		Сообщить("Очистка данных по организации " + УдаляемаяОрганизация + "...");
		Сообщить("-------------------------------------------------------------");
		ОчиститьОсновныеДоговорыПоОрганизации(УдаляемаяОрганизация);
		ОчиститьРегистрыСведенийПоОрганизации(УдаляемаяОрганизация);
		ОчиститьРегистрыСведенийПоПодразделенениямОрганизации(УдаляемаяОрганизация);
		ОчиститьДанныеПоОрганизации(УдаляемаяОрганизация);
		
	КонецЦикла; 
		
КонецПроцедуры

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

Процедура ОбновитьСписокУдаляемыхОрганизаций()
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	Организации.Ссылка КАК Ссылка
	|ИЗ
	|	Справочник.Организации КАК Организации
	|
	|УПОРЯДОЧИТЬ ПО
	|	Ссылка
	|АВТОУПОРЯДОЧИВАНИЕ";
	СписокУдаляемыхОрганизаций.ЗагрузитьЗначения(Запрос.Выполнить().Выгрузить().ВыгрузитьКолонку("Ссылка"));
	
КонецПроцедуры

Процедура ПриОткрытии()
	
	ОбновитьСписокУдаляемыхОрганизаций();
	
КонецПроцедуры

Процедура СписокУдаляемыхОрганизацийВыбор(Элемент, ЭлементСписка)
	
	ОткрытьЗначение(ЭлементСписка.Значение);
	
КонецПроцедуры

 Для ленивых сама обработка:

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

См. также

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

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

24900 руб.

20.08.2024    68670    360    164    

315

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

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

6100 руб.

16.03.2015    281083    258    84    

291

Чистка данных Системный администратор Программист 1С:Предприятие 8 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. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 26.02.2026, версия 4.5, 4.6.0)

14640 руб.

22.02.2013    146656    291    153    

459

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

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

23999 руб.

20.02.2026    1269    1    0    

4

Чистка данных Программист Пользователь 1С:Предприятие 8 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    30592    82    21    

97

Чистка данных Инструменты администратора БД Системный администратор Программист 1С 8.3 1С:Управление торговлей 10 1С:Управление торговлей 11 1С:Библиотека стандартных подсистем Абонемент ($m)

Хочешь выборочно удалить одну организацию, тестовую номенклатуру или «мусорного» контрагента, любую ссылку - без ручного поиска ссылок и часовых разборок зависимостей? Этот инструмент сам строит дерево связей, каскадно чистит с "глубоким поиском" документы, справочники, пвх, любые ссылки, регистры, движения в так же делает резервную копию и за пару минут оставляет базу чистой и полностью работоспособной (Управляемые формы, обычный интерфейс)

1 стартмани

03.02.2026    2862    104    war41k    0    

26

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

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

1 стартмани

25.12.2023    14113    316    WeterSoft    7    

16
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Valerich 1638 03.12.15 12:16 Сейчас в теме
а потом попробуйте все помеченное на удаление удалить из базы
2. q_i 587 08.12.15 21:26 Сейчас в теме
(1) Valerich, пробовал - удаляется. Желательно, правда, итоги отключить. А Вас что смущает?
Для отправки сообщения требуется регистрация/авторизация