Битые ссылки. Поиск, удаление, восстановление.

Опубликовал nalivai-chai в раздел Администрирование - Сервисные утилиты

Поиск битых ссылок в базе данных.
Возможности:
    - отбор таблиц данных по объектам метаданных;
    - управление результатом поиска (перегруппировка);
    - восстановление битых ссылок из резервной копии;
    - удаление объектов с битыми ссылками;
    - подстановка пустых значений вместо битых ссылок;
    - установка/снятие пометки удаления ссылочных объектов с битыми ссылками;
    - отчет по результату поиска битых ссылок (на СКД со всеми возможностями настройки).

Поиск битых ссылок с выбором объектов метаданных, в таблице данных которых нужно найти битые ссылки.

Удобное представление результата поиска битых ссылок с настройкой группировки данных.

Вывод найденных битых ссылок в табличный документ (СКД).

Могут возникнуть ошибки при выполнении обработки на клиент-серверном варианте ИБ, связанные со сложностью запросов для поиска битых ссылок.

Обработка позволяет проводить некоторые манипуляции с битыми ссылками.

Функции:

1. восстановление объектов битых ссылок из резервной копии с возможностью выбора объектов для восстановления;

2. замена битых ссылок пустыми;

3. пометка на удаление ссылочных объектов с битыми ссылками;

4. удаление объектов с битыми ссылками.

 

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

Имеются следующие полезные экспортные функции:


//  Возвращает таблицу битых ссылок
//  МассивМетаданных - массив метаданных, в которых нужно искать битые ссылки
//  ИсключитьМетаданные - массив метаданных для исключения
//  Таблица - объект таблицы значений в который нужно поместить данные (таблица очищается полностью)
//  ИсточникПодробно - (истина/ложь) расшифровка источника до ссылки или ключа записи
Функция ПолучитьТаблицуБитыхСсылок(ОбъектыМетаданных = Неопределено, ОбъектыМетаданныхИсключить = Неопределено, Таблица = Неопределено, ИсточникПодробно = Ложь, ПоказатьИндикатор = Истина) Экспорт
 

//  Свойства (структура):
//      Реквизиты - соответствие (ОбъектМетаданных - СтрокаРеквизитов)
//      ПоказатьИндикатор (Булево)
//      РежимЗагрузкиПриОбменеДанными (Булево),
//      МетодыОчисткиРегистровСведений (Соответствие), Методы: "Перезапись", "УдалениеПоЗаписям"
//      ОчищатьРегистрыПоРеквизитуРегистратор (Булево)
Функция ОчиститьДанныеОтБитыхСсылок(ОбъектыМетаданных = Неопределено, ОбъектыМетаданныхИсключить = Неопределено, ТаблицаБитыхСсылок = Неопределено, Свойства = Неопределено) Экспорт
 

//  Восстанавливает битые ссылки в массиве из внешней информационной базы
//  Свойства - структура:
//      РежимЗагрузкиПриОбменеДанными (Булево)
Функция ВосстановитьБитыеСсылкиИзВнешнейИнформационнойБазы(МассивБитыхСсылок, Соединение, Свойства = Неопределено) Экспорт

 

Обработка проверена на конфигурациях: УПП, БП, ЗУП, УТ и проч.

Исправлены найденные ошибки. См. комментарии. 

http://forum.infostart.ru/forum24/topic46716/message511514/#message511514

http://forum.infostart.ru/forum24/topic46716/message512103/#message512103

Спасибо Kolespvlunegov.

Оптимизированы запросы поиска битых ссылок.

06.04.2012. Исправлена ошибка с переменной "глОбщиеЗначения". Добавлена возможность установки владельца при создании элемента по битой ссылке с владельцем.

Файлы

Наименование Файл Версия Размер Кол. Скачив.
Обработка поиска битых ссылок
.epf 71,76Kb
06.04.12
1418
.epf 71,76Kb 1418 Скачать

См. также

Лучшие комментарии

12. Koles (файл скачал) 28.11.2011 09:01
Управление торговлей 10.3 такое выдала:
{ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(1482)}: Ошибка при вызове метода контекста (Выполнить)
Выборка = Запрос.Выполнить().Выбрать();
по причине:

по причине:
{(37, 21)}: Поле не найдено "ТочкаМаршрута.ВерсияДанных"
ИЛИ (ТочкаМаршрута.<<?>>ВерсияДанных ЕСТЬ NULL
+ 1 [ nalivai-chai; ]
# Ответить
21. nalivai-chai 30.11.2011 13:34
(19) Oli29,
Oli29 пишет:
База БУ8 оказалась сбойной "Файл базы данных поврежден..."


Маловероятно, что проблема вообще в битых ссылках.
Может Вам поможет утилита от 1С: "C:\Program Files\1cv82\8.2.14.528\bin\chdbfl.exe"(19) Oli29,
Ответили: (23) (59)
+ 1 [ IgorXml; ]
# Ответить
8. pvlunegov (файл скачал) 25.11.2011 15:59
Извините за незнание сайта Инфостарт... У меня возникла идея создать тему - что полезного можно улучшить в 1С в плане функционала...

Может уже есть что-то подобное, я просто не видел.

На самом деле идей куча, в основном касаемо интерфейса, удобства..
Большинство негативных реакций на неудобства быстро забываются пользователями, они привыкают к ним.
И ЭТО НЕХОРОШО.

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

Причем просьбы от пользователей иногда очень неожиданные, даже странные, НА ПЕРВЫЙ ВЗГЛЯД.
Если их просьбы воплотить, то работать в 1С станет намного удобнее и быстрее
+ 1 [ CaSH_2004; ]
# Ответить

Комментарии

1. Культурный 21.11.2011 13:29
Чем отличается от удаления битых ссылок в Тестировании и исправлении?
# Ответить
2. nalivai 21.11.2011 13:46
Тем что можно обработать конкретные объекты, проанализировать ситуацию, сохранить время на том, чтобы не анализировать всю базу, а выбранные объекты, да и вроде работает пошустрей, чем стандартное тестирование.
В РИБе битые ссылки это нормальная ситуация и нужно обработать базу данных выборочно.
Обработка не претендует на уникальность.
Ответили: (9)
# Ответить
3. Культурный 21.11.2011 14:12
Для РИБ выборочное тестирование правда тема.
# Ответить
4. cdb (файл скачал) 21.11.2011 19:41
Спасибо за обработку. Простенько и со вкусом. Мне по крайней мере пригодилась.
# Ответить
5. pvlunegov (файл скачал) 25.11.2011 09:28
Спасибо за обработку. Полезна для мониторинга ситуации. Особенно когда лень запускать Тестирование и Исправление.
1С-овцы лень было сделать что-то подобное, за что автору спасибо.
Кстати, у 1С много таких маленьких доработок можно сделать.
Вроде как уже есть типовой функционал, но у автора он удобнее, нагляднее.
ЗА что спасибо автору!

P.S. Лень программиста - двигатель прогресса...
Ответили: (6) (7)
# Ответить
6. dashanika 25.11.2011 14:57
присоединяюсь к (5).
Спасибо большое! и в правду, не хватает у 1с интерфеса чуток...
# Ответить
7. nataon 25.11.2011 15:45
Согласна с (5).
# Ответить
8. pvlunegov (файл скачал) 25.11.2011 15:59
Извините за незнание сайта Инфостарт... У меня возникла идея создать тему - что полезного можно улучшить в 1С в плане функционала...

Может уже есть что-то подобное, я просто не видел.

На самом деле идей куча, в основном касаемо интерфейса, удобства..
Большинство негативных реакций на неудобства быстро забываются пользователями, они привыкают к ним.
И ЭТО НЕХОРОШО.

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

Причем просьбы от пользователей иногда очень неожиданные, даже странные, НА ПЕРВЫЙ ВЗГЛЯД.
Если их просьбы воплотить, то работать в 1С станет намного удобнее и быстрее
+ 1 [ CaSH_2004; ]
# Ответить
9. AlexO 27.11.2011 01:53
(2) nalivai,
что за отдельный вид битых ссылок "битые ссылки в РИБ"??
и что значит "выбираем объекты", когда поиск битых ссылок - это поиск по всей базе?
Смысл посика таких ссылок - это освободить базу от них, и очистить документы от несуществующих ссылок, а не ОБЪЕКТЫ.
А возникнуть они могут везде и всюду...
Я сам пользуюсь запросом, да и поиск так называемых "битых ссылок" - занятие нетривиальное: ссылки могут быть <12FG-1254-....>; могут быть необновлены (как в РИБ - ссылка по удаленной базе "жива", а на самом деле - уже не существует, ошибка такая, синхронизация баз не всегда верно обновляет ссылки; могут быть "<объект не найден>" и т.д....
Вы конкретный механизм поиска можете описать? что ищете, что удаляете..
а то опять все на новичков рачитано - "удаляем ссылки! спешите!"
ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?
Ответили: (11)
# Ответить
10. amatisol 27.11.2011 22:07
Спасибо за обработку. Полезна для мониторинга ситуации. Особенно когда лень запускать Тестирование и Исправление.
1С-овцы лень было сделать что-то подобное, за что автору спасибо.
Кстати, у 1С много таких маленьких доработок можно сделать.
Вроде как уже есть типовой функционал, но у автора он удобнее, нагляднее.
ЗА что спасибо автору!
# Ответить
11. nalivai 27.11.2011 22:55
AlexO пишет:
что за отдельный вид битых ссылок "битые[IS-QUOTE]AlexO пишет:
ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?
ссылки в РИБ"??[/IS-QUOTE](9) AlexO,
Вроде я нигде не классифицировал битые ссылки.
В РИБ (распределенная информационная база) битые ссылки - вполне естественное явление, и если есть битая ссылка, то это ещё не значит, что возникла, какая-то ошибка.
AlexO пишет:
что значит "выбираем объекты", когда поиск битых ссылок - это поиск по всей базе

Это значит:
1. если я знаю что в регистре сведений "ОДИН" есть битые ссылки, но мне они не интересны, то я могу исключить его из рассмотрения и не тратить на него времени.
2. если вдруг найдена битая ссылка с контрагентом в документе какого-то вида, я хочу посмотреть, а в каких ещё документах этого вида, есть битые ссылки.
3. я точно знаю, что в объектах какого-то вида нет битых ссылок или мне их наличие безразлично, то зачем тратить время на эти объекты.


AlexO пишет:
Смысл посика таких ссылок - это освободить базу от них, и очистить документы от несуществующих ссылок

и это в том числе, решений может быть много, в обработке есть все механизмы для того чтобы решить эту задачу просто. Нужно добавить пару строк и использовать готовые фунцкии))).
Интересно как очистить поле "Регистратор" регистра сведений, если он является битой ссылкой, не удаляя при этом строку из регистра?
AlexO пишет:
ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?

На этот вопрос отвечу в публикации.
# Ответить
12. Koles (файл скачал) 28.11.2011 09:01
Управление торговлей 10.3 такое выдала:
{ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(1482)}: Ошибка при вызове метода контекста (Выполнить)
Выборка = Запрос.Выполнить().Выбрать();
по причине:

по причине:
{(37, 21)}: Поле не найдено "ТочкаМаршрута.ВерсияДанных"
ИЛИ (ТочкаМаршрута.<<?>>ВерсияДанных ЕСТЬ NULL
+ 1 [ nalivai-chai; ]
# Ответить
13. Koles (файл скачал) 28.11.2011 09:35
Если кнопку очистка регистров нажать, тогда:
{Форма.Форма.Форма(905)}: Поле объекта не обнаружено (ШтатноеРасписаниеОрганизаций)
МетодыОчисткиРегистровСведений.Вставить(Метаданные.РегистрыСведений.ШтатноеРасписаниеОрганизаций, "Перезапись");
Обработка под конкретную конфигурацию?
# Ответить
14. nalivai 28.11.2011 09:58
Спасибо, будет исправлено.
# Ответить
15. pvlunegov (файл скачал) 28.11.2011 15:20
1С 8.2 "Комплексная Автоматизация" при запуске поиска битых ссылок, строка состояния заполнялась примерно до 30%, после чего выдавалось сообщение:

{ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(1286)}: Ошибка при вызове метода контекста (Выполнить)
Выборка = Запрос.Выполнить().Выбрать();
по причине:

по причине:
{(1090, 6)}: Превышение допустимой вложенности операций
<<?>>ИЛИ СсылкаОбъекта = ЗНАЧЕНИЕ(Справочник.КлючиАналитикиУчетаПартий.ПустаяСсылка)

Лень была разбираться в ошибках, автору на заметку...
# Ответить
16. pvlunegov (файл скачал) 28.11.2011 15:23
ЗЫ...

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

Автору просьба прокомментировать ошибку, которую я описал выше, возможно это натолкнет меня на то, где копать.
Заранее спасибо.
# Ответить
17. pvlunegov (файл скачал) 28.11.2011 15:35
ЗЫ.

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

Нехороший признак... Автору незачет!

Обработки, такого пошиба, как у вас (поиск чего-то в неизвестной базе) на мой взгляд, должны обладать по меньшей мере устойчивостью к незнакомой базе. Я имею ввиду, что если какого то справочника случайно не оказалось в подопытной базе, то обработка не должна спотыкаться, а должна продолжать работу.
Для этого 1С-ники специально придумали оператор "попытка...исключение...конецпопытки".
Этот оператор можно использовать вложенно, аналогично оператору "если...иначе...конецесли".

Кстати, тут интересная аналогия с боевыми действиями. На учениях сержант проверяет по списку людей(справочники)...
- Иванов?
- Я!
- Сидоров?
- Нету его, он в туалет пошел!
- меня не колебет, пока не будет в строю, все будут его ждать!
ТА-ЖЕ ситуация во время войны... (Обработка, устойчивая к незнакомой конфигурации)
Сержант проверяет по списку солдат:
- Иванов?
- Я!
- Сидоров?
- Нету его, он ПОГИБ СМЕРТЬЮ ХРАБРЫХ!
- Ну и фиг с ним, дальше по списку пойдем...
- Гаврилов?
+ 1 [ nalivai-chai; ]
# Ответить
18. nalivai 28.11.2011 21:04
pvlunegov пишет:
{ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(1286)}: Ошибка при вызове метода контекста (Выполнить)
Выборка = Запрос.Выполнить().Выбрать();
по причине:

по причине:
{(1090, 6)}: Превышение допустимой вложенности операций
<<?>>ИЛИ СсылкаОбъекта = ЗНАЧЕНИЕ(Справочник.КлючиАналитикиУчетаПартий.ПустаяСсылка)


Спасибо за найденные ошибки, анекдот в кассу)))
Все исправил.
Проверил работу обработки на УПП. Все ОК.
# Ответить
19. Oli29 (файл скачал) 30.11.2011 11:46
А мне обработка не помогла.
База БУ8 оказалась сбойной "Файл базы данных поврежден...", такую ошибку выдает и при выгрузке базы и при тестировании,Короче в некоторых случаях вылетает и не хочет дальше ни работать, ни исправлять ошибки.
Ваша обработка отработала без вылетов, но и ошибок не обнаружила. А я так надеялась. Может нужно попробовать другую обработку-реаниматор?
Ответили: (21)
# Ответить
20. verad (файл скачал) 30.11.2011 12:57
Обработка не работает в SQL-базе, превышение максимального количества таблиц в запросе. Пробовала отметить в дереве метаданных хотя бы просто один! вид документа - получаю эту ошибку. Если бы работала - была бы очень полезная вещь.
Ответили: (22)
# Ответить
21. nalivai-chai 30.11.2011 13:34
(19) Oli29,
Oli29 пишет:
База БУ8 оказалась сбойной "Файл базы данных поврежден..."


Маловероятно, что проблема вообще в битых ссылках.
Может Вам поможет утилита от 1С: "C:\Program Files\1cv82\8.2.14.528\bin\chdbfl.exe"(19) Oli29,
Ответили: (23) (59)
+ 1 [ IgorXml; ]
# Ответить
22. nalivai-chai 30.11.2011 13:38
(20) verad,

verad пишет:
Обработка не работает в SQL-базе


.... не для всех объектов метаданных.
Остается только, выгрузить в файловую базу.
# Ответить
23. Oli29 (файл скачал) 30.11.2011 16:59
(21) nalivai-chai,
Спасибо, действительно помогла эта утилитка, и база исправилась.
# Ответить
25. vetalm (файл скачал) 22.01.2012 20:34
задумка и подход мегакул но результат не удовлетворяет.
Моя история: необходимо почистить регистры накопления без регистраторов - отмечаю необходимые регистры, ищу битые ссылки, находит приблизительно 10000 записей, отмечаю объекты по реквизиту регистратор, удаляю. Со списка вродь как все удаляются но когда смотрю список регистров накопления битые записи всеже на месте. Обработкой "регистрация изменений" объектов для РИБ смотрю то в нужном регистре появляются 10000 записей измененных. Запускаю на обработке "поиск битых ссылок" вновь поиск опять находятся все теже 10000 записей. Вобщем чевойто то тут не все доделано.
# Ответить
26. tormozit (файл скачал) 19.02.2012 10:55
Интересное творение
# Ответить
27. Klondaik (файл скачал) 25.02.2012 22:12
Спасибо за обработку. Удобный интерфейс, функционал понравился..Вобщем почистил базу нормально:)
# Ответить
28. pvlunegov (файл скачал) 12.03.2012 14:15
Спасибо за обработку! Поставил плюс. Некогда было разбираться с другими возможностями.
В своей базе заменил кучу битых ссылок на пустые. Быстро и эффективно.

Но!
Автора прошу в модуле объекта добавить строку:
"
Перем глОбщиеЗначения;
"

Иначе ругань при открытии обработки.
А так все вроде работает.
+ 1 [ v_id; ]
# Ответить
29. Жолтокнижниг (файл скачал) 13.03.2012 17:27
Заочно +1, завтра буду тестить если что отпишусь
# Ответить
30. Sairys (файл скачал) 05.05.2012 18:00
Обработка отличная, мне очень понравилась, а главное базу не грузит во время поиска. Да и ищет быстро. И очень удобная, автору респект
# Ответить
31. Tur_gad (файл скачал) 21.06.2012 09:22
Обработка супер. Но нельзя ли такуюже под 8,1 скинуть пожалуйста ОЧЕНЬ НАДО!!!!!!!!!!!
Ответили: (32)
# Ответить
32. nalivai-chai 29.06.2012 20:36
(31) Tur_gad,
Нет платформы 8.1 под рукой.
Но...
Вы можете попробовать сделать обратную конвертацию следующим путем:
- добавить обработку в конфигурацию на платформе 8.2,
- затем скопировать её в буфер (Ctrl+C),
- открыть любую конфигурацию на платформе 8.1
- выбрать ветку обработки и вставить обработку из буфера (Ctrl+V).
Должно получиться.
Сам не пробывал, но слышал о таком методе.
# Ответить
33. marku (файл скачал) 17.08.2012 09:53
Хорошо бы вставить ОбработкаПрерыванияПользователя()
# Ответить
34. 1977 (файл скачал) 21.08.2012 13:05
Под УТ11 не запустилось!!!
Ответили: (35)
# Ответить
35. nalivai-chai 21.08.2012 13:28
(34) 1977, запустите в "обычном приложении", не в "управляемом".
# Ответить
36. 1977 (файл скачал) 21.08.2012 13:48
Значить не пойдет в Ут11.
Ответили: (37)
# Ответить
37. nalivai-chai 21.08.2012 14:30
(36) 1977, да почему же не пойдет?
Подскажу: Открываете конфигуратор. Главное меню -> Отладка -> Начало отладки -> Толстый клиент (обычное приложение): начать отладку.

Откроется ваша УТ11 с обычным инетрфейсом. Без всяких интерфейсов и красивостей. Но зато можно запустить обработку с обычным интерфесом.
# Ответить
38. 1977 (файл скачал) 21.08.2012 15:06
Там такого нету!!
Ответили: (39)

Прикрепленные файлы:

толстый.jpg
# Ответить
39. nalivai-chai 17.11.2012 20:48
(38) 1977, В конфигураторе нужно установить параметры:

Главное меню -> Сервис -> Параметры... -> вкладка "Общие" -> выбрать "Управляемое приложение и управляемое приложение";

тогда будет доступен запуск отладки в режиме " Толстый клиент (обычное приложение)".
# Ответить
40. Jon2011 (файл скачал) 17.12.2012 12:32
У меня всегда вызывало сомнение, при запуске стандартной ТИ, что выбирать - удаление битых ссылок или восстановление объекта, потому как нужное выбирать приходится в темную. А здесь всегда можно посмотреть с чем связана ссылка и окончательно решить, что с ней делать.
Безусловно полезная обработка. Однозначно плюс.
# Ответить
41. teplova (файл скачал) 21.05.2013 07:21
Здравствуйте, у меня БП 8.2. Есть битая ссылка. Но Ваша обработка ее не находит почему-то.
Ответили: (42)
# Ответить
42. nalivai-chai 21.05.2013 19:33
(41) teplova, скажите, пожалуйста, с какими объектами связана битая ссылка (тип битой ссылки, в объекте какого типа она обнаружена)?
# Ответить
43. echo77 (файл скачал) 13.06.2013 10:07
Отличная вещь! Правда пока почему-то не получилось подключиться к внешней базе
Если бы можно было бы сохранять настройки - было бы вообще здорово!
# Ответить
44. echo77 (файл скачал) 14.06.2013 08:35
(0) Ошибка при попытке установить пометки на удаление для объектов с битыми ссылками в табличных частях.

Прикрепленные файлы:

Ошибка.png
Ошибка1.png
# Ответить
45. stupid01 (файл скачал) 12.08.2013 15:50
Спасибо!
Помогло
# Ответить
46. ls300 (файл скачал) 15.08.2013 02:10
Огромное спасибо, за обработку! Не было времени выдумывать свою, а восстанавливать надо..
# Ответить
47. Synoecium (файл скачал) 19.09.2013 15:26
Хорошая обработка, вот только при выполнении "Очистка регистров" выдало следующую ошибку:

Возникла ошибка при обработке объекта: РегистрСведений.АналитикаУчетаПрочихЗатрат
{ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(1592)}: Ошибка при вызове метода контекста (Выполнить)
Выборка = Запрос.Выполнить().Выбрать();
по причине:
Ошибка выполнения запроса
по причине:
Построенный запрос к СУБД использует слишком много таблиц. Допустимо не более 256.
Microsoft OLE DB Provider for SQL Server: Too many table names in the query. The maximum allowable is 256.

Это можно как-то обойти?
Конфигурация: УПП 1.3.40.1, платформа 8.2
Ответили: (48)
# Ответить
48. nalivai-chai 19.09.2013 16:01
(47) Synoecium, если база не совсем огромная, то можно равзернуть как файловую. На файловой такой ошибки не должно быть. Вообще есть обработка, где решена эта проблема, в ближайшие дни постараюсь выложить.
# Ответить
49. insurgut (файл скачал) 15.10.2013 07:29
Отличная обработка! Не раз выручала :)
# Ответить
50. shmellevich 31.10.2013 17:13
Спасибо, автору, за золотые руки!!! Только что, очень помогло восстановить все битые Товары и к ним подчиненные справочники )))
# Ответить
51. 7OH (файл скачал) 20.11.2013 14:37
Поддерживаю идею о сохранении настроек.
И после поиска логично переходить в список найденного.
Ответили: (52)
# Ответить
52. gaglo (файл скачал) 21.11.2013 10:03
Обработка хороша. Богатые возможности, добрый интерфейс. И ещё - она работает! (Это главное!)
НО, конечно, есть мелкие замечания - возможно, на будущее...
Запускал в конфигурации, где нет общей формы ХодВыполненияОбработкиДанных. Выборка, конечно, идет, но без всякой индикации, и (по-моему) постоянная обработка исключений в этом случае затянула цикл вдвое. Наверное, стоило бы индикацию процесса сделать через Состояние - скромненько, но и быстренько.
Стоило бы добавить еще возможность отбора типов битых ссылок для поиска - скажем, только ссылки на единицы измерения. При решении уже известных проблем время бы экономилось.
Ну и, конечно, то, что в (51) - поддерживаю.
# Ответить
53. tanselja 13.03.2014 12:09
Классная обработка!!!!!
# Ответить
54. васисубатор (файл скачал) 20.11.2014 22:13
Пользователи теперь запрещенная переменная (при подключении к копии базы) - изменил, в остальном классная штука
# Ответить
55. pavelyar 23.12.2014 11:58
А в УФ работает обработка?
# Ответить
56. nalivai-chai 23.12.2014 13:20
57. DAnry (файл скачал) 08.02.2015 17:16
Спасибо автору! Очень полезная вещь. Пользуюсь. Вот только не всегда коректно работает удаление объектов с битыми ссылками.
Форма.Форма.Форма(864)}: Помилка при виклику методу контексту (Удалить)
НаборЗаписей.Удалить(ЗаписьДляУдаления);
через:
Неприпустиме значення параметру (параметр номер '1')
Ответили: (58)
# Ответить
58. nalivai-chai 12.02.2015 01:53
(57) DAnry, спасибо за ошибку, постараюсь устранить.
# Ответить
59. IgorXml (файл скачал) 18.03.2015 15:38
(21) nalivai-chai, Спасибо, это помогло - утилита от 1С: "C:\Program Files\1cv82\8.2.XXX.XXX\bin\chdbfl.exe"
Обновляли файловую базу на БП 2.0.64 и прервали.
Обработкой делать пробовал, но ничего не получилось:

Прикрепленные файлы:

Попытки.png
# Ответить
60. GERMANTAGIL (файл скачал) 13.10.2015 06:50
Обработка понравилась и действительно работает.
Ситуация была следующая
Суть проблемы - удалили участок на предприятии
идем в справочники-предприятие-подразделения
открывается хрень
слева - структура предприятия
справа - подразделения организаций
дак вот - то что слева я поднял встало вроде нормально
причем поднимал обработкой - GUID
https://w1c.ru/epf-1.html

А вот справа - GUID работает некорректно
орет что нужен "владелец"
ну дак вот давай я думать как обмануть адрес вроде есть а к чему привязать
Вопрос был вроде простой как по битой ссылке найти все записи -
хотя я и понимал что мне нужно восстановить только один обьект.
Поискал в Инете ну все не то - все не так работает.
подразделения организаций (когда созадется подразделение) - GUID работает некорректно
система 1С - орет что нужен "владелец"
Ваша обработка отработала корректно - восстановила все 168 документов
Но у меня вопрос автору -
1. хотелось бы обработку которая по <Объект не найден> (84:893f00215aecf30a11e0760ca6c900fd) искала бы все вхождения
чтобы можно было представлять какие документы справочники и т.д. были "задеты" (в архивах может другое количество записей)
2. Нетривиальная задача восстановления элемента номенклатуры вместе с единицами измерения (те хотелось бы вариант при воссстановлении элемента номенклатуры подвязывалась еденица измерения правильная - иначе придется бродить по множеству документов)
в ручную я вроде нашел вариант который работает а вот обработок подобного типа вообще не видел
Еще раз большое спасибо
Ответили: (61)
# Ответить
61. insurgut (файл скачал) 19.10.2015 07:25
(60) GERMANTAGIL, системе пофиг на владельца, если "ОбменДанными.Загрузка = Истина;" :)
# Ответить
62. mvmish (файл скачал) 11.12.2015 15:56
Не работает обработка!
Ответили: (63)
# Ответить
63. nalivai-chai 11.12.2015 22:34
(62) mvmish, а подробнее? :)
# Ответить
64. madway (файл скачал) 23.03.2016 17:43
Отличный инструмент. Нужно было восстановить битые ссылки в одной из РИБ. Соединился с другой базой , вытащил данные.
Одно пожелание, сделайте возможность выбора компонента для соединения Com82 или com83.
# Ответить
65. CheBurator 17.05.2016 22:16
Непонятно, можно ли битую ссылку заменить другой, нормальной?
Ответили: (66)
# Ответить
66. tormozit (файл скачал) 18.05.2016 01:05
(65) В ИР из аналогичного инструмента "Поиск битых ссылок" можно передать битую ссылку в подбор и обработку объектов, добавить правильную ссылку, передать обе ссылки в обработку "Объединить ссылки".
Ответили: (67)

Прикрепленные файлы:

2016-05-18_010240.gif
2016-05-18_010336.gif
2016-05-18_010352.gif
# Ответить
67. CheBurator 18.05.2016 20:58
(66) учтем
# Ответить
Внимание! За постинг в данном форуме $m не начисляются.
Внимание! Для написания сообщения необходимо авторизоваться
Текст сообщения*
Прикрепить файл