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








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

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

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

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

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

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

Функции:

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

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

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

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

 

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

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


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

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

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

 

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

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

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

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

Спасибо Kolespvlunegov.

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

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

78 Comments

  1. Культурный

    Чем отличается от удаления битых ссылок в Тестировании и исправлении?

    Reply
  2. nalivai-chai

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

    В РИБе битые ссылки это нормальная ситуация и нужно обработать базу данных выборочно.

    Обработка не претендует на уникальность.

    Reply
  3. Культурный

    Для РИБ выборочное тестирование правда тема.

    Reply
  4. cdb

    Спасибо за обработку. Простенько и со вкусом. Мне по крайней мере пригодилась.

    Reply
  5. pvlunegov

    Спасибо за обработку. Полезна для мониторинга ситуации. Особенно когда лень запускать Тестирование и Исправление.

    1С-овцы лень было сделать что-то подобное, за что автору спасибо.

    Кстати, у 1С много таких маленьких доработок можно сделать.

    Вроде как уже есть типовой функционал, но у автора он удобнее, нагляднее.

    ЗА что спасибо автору!

    P.S. Лень программиста — двигатель прогресса…

    Reply
  6. dashanika

    присоединяюсь к (5).

    Спасибо большое! и в правду, не хватает у 1с интерфеса чуток…

    Reply
  7. nataon

    Согласна с (5).

    Reply
  8. pvlunegov

    Извините за незнание сайта Инфостарт… У меня возникла идея создать тему — что полезного можно улучшить в 1С в плане функционала…

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

    На самом деле идей куча, в основном касаемо интерфейса, удобства..

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

    И ЭТО НЕХОРОШО.

    Было бы полезно создать такую тему для того, чтобы люди скидывали туда свои идеи, а знающие люди могли бы их воплощать…

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

    Причем просьбы от пользователей иногда очень неожиданные, даже странные, НА ПЕРВЫЙ ВЗГЛЯД.

    Если их просьбы воплотить, то работать в 1С станет намного удобнее и быстрее

    Reply
  9. AlexO

    (2) nalivai,

    что за отдельный вид битых ссылок «битые ссылки в РИБ»??

    и что значит «выбираем объекты», когда поиск битых ссылок — это поиск по всей базе?

    Смысл посика таких ссылок — это освободить базу от них, и очистить документы от несуществующих ссылок, а не ОБЪЕКТЫ.

    А возникнуть они могут везде и всюду…

    Я сам пользуюсь запросом, да и поиск так называемых «битых ссылок» — занятие нетривиальное: ссылки могут быть <12FG-1254-….>; могут быть необновлены (как в РИБ — ссылка по удаленной базе «жива», а на самом деле — уже не существует, ошибка такая, синхронизация баз не всегда верно обновляет ссылки; могут быть «<объект не найден>» и т.д….

    Вы конкретный механизм поиска можете описать? что ищете, что удаляете..

    а то опять все на новичков рачитано — «удаляем ссылки! спешите!»

    ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?

    Reply
  10. amatisol

    Спасибо за обработку. Полезна для мониторинга ситуации. Особенно когда лень запускать Тестирование и Исправление.

    1С-овцы лень было сделать что-то подобное, за что автору спасибо.

    Кстати, у 1С много таких маленьких доработок можно сделать.

    Вроде как уже есть типовой функционал, но у автора он удобнее, нагляднее.

    ЗА что спасибо автору!

    Reply
  11. nalivai-chai
    AlexO пишет:

    что за отдельный вид битых ссылок «битые[IS-QUOTE]AlexO пишет:

    ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?

    ссылки в РИБ»??[/IS-QUOTE](9) AlexO,

    Вроде я нигде не классифицировал битые ссылки.

    В РИБ (распределенная информационная база) битые ссылки — вполне естественное явление, и если есть битая ссылка, то это ещё не значит, что возникла, какая-то ошибка.

    AlexO пишет:

    что значит «выбираем объекты», когда поиск битых ссылок — это поиск по всей базе

    Это значит:

    1. если я знаю что в регистре сведений «ОДИН» есть битые ссылки, но мне они не интересны, то я могу исключить его из рассмотрения и не тратить на него времени.

    2. если вдруг найдена битая ссылка с контрагентом в документе какого-то вида, я хочу посмотреть, а в каких ещё документах этого вида, есть битые ссылки.

    3. я точно знаю, что в объектах какого-то вида нет битых ссылок или мне их наличие безразлично, то зачем тратить время на эти объекты.

    AlexO пишет:

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

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

    Интересно как очистить поле «Регистратор» регистра сведений, если он является битой ссылкой, не удаляя при этом строку из регистра?

    AlexO пишет:

    ЧТО КОНКРЕТНО ДЕЛАЕТ ОБРАБОТКА?

    На этот вопрос отвечу в публикации.

    Reply
  12. Koles

    Управление торговлей 10.3 такое выдала:

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

    Выборка = Запрос.Выполнить().Выбрать();

    по причине:

    по причине:

    {(37, 21)}: Поле не найдено «ТочкаМаршрута.ВерсияДанных»

    ИЛИ (ТочкаМаршрута.<<?>>ВерсияДанных ЕСТЬ NULL

    Reply
  13. Koles

    Если кнопку очистка регистров нажать, тогда:

    {Форма.Форма.Форма(905)}: Поле объекта не обнаружено (ШтатноеРасписаниеОрганизаций)

    МетодыОчисткиРегистровСведений.Вставить(Метаданные.РегистрыСведений.ШтатноеРасписаниеОрганизаций, «Перезапись»);

    Обработка под конкретную конфигурацию?

    Reply
  14. nalivai-chai

    Спасибо, будет исправлено.

    Reply
  15. pvlunegov

    1С 8.2 «Комплексная Автоматизация» при запуске поиска битых ссылок, строка состояния заполнялась примерно до 30%, после чего выдавалось сообщение:

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

    Выборка = Запрос.Выполнить().Выбрать();

    по причине:

    по причине:

    {(1090, 6)}: Превышение допустимой вложенности операций

    <<?>>ИЛИ СсылкаОбъекта = ЗНАЧЕНИЕ(Справочник.КлючиАналитикиУчетаПартий.ПустаяСсылка)

    Лень была разбираться в ошибках, автору на заметку…

    Reply
  16. pvlunegov

    ЗЫ…

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

    Автору просьба прокомментировать ошибку, которую я описал выше, возможно это натолкнет меня на то, где копать.

    Заранее спасибо.

    Reply
  17. pvlunegov

    ЗЫ.

    Автору на заметку — в ошибке ругалось на справочник Справочник.КлючиАналитикиУчетаПартий.

    Попытался убрать галки в списке, чтобы обработка не проверяла его.

    Не помогло, все равно выскакивает ошибка.

    Таким образом, несмотря на то, что в списке проверке справочника нет, он в коде все равно проверяется.

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

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

    Для этого 1С-ники специально придумали оператор «попытка…исключение…конецпопытки».

    Этот оператор можно использовать вложенно, аналогично оператору «если…иначе…конецесли».

    Кстати, тут интересная аналогия с боевыми действиями. На учениях сержант проверяет по списку людей(справочники)…

    — Иванов?

    — Я!

    — Сидоров?

    — Нету его, он в туалет пошел!

    — меня не колебет, пока не будет в строю, все будут его ждать!

    ТА-ЖЕ ситуация во время войны… (Обработка, устойчивая к незнакомой конфигурации)

    Сержант проверяет по списку солдат:

    — Иванов?

    — Я!

    — Сидоров?

    — Нету его, он ПОГИБ СМЕРТЬЮ ХРАБРЫХ!

    — Ну и фиг с ним, дальше по списку пойдем…

    — Гаврилов?

    Reply
  18. nalivai-chai
    pvlunegov пишет:

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

    Выборка = Запрос.Выполнить().Выбрать();

    по причине:

    по причине:

    {(1090, 6)}: Превышение допустимой вложенности операций

    <<?>>ИЛИ СсылкаОбъекта = ЗНАЧЕНИЕ(Справочник.КлючиАналитикиУчетаПартий.ПустаяСсылка)

    Спасибо за найденные ошибки, анекдот в кассу)))

    Все исправил.

    Проверил работу обработки на УПП. Все ОК.

    Reply
  19. Oli29

    А мне обработка не помогла.

    База БУ8 оказалась сбойной «Файл базы данных поврежден…», такую ошибку выдает и при выгрузке базы и при тестировании,Короче в некоторых случаях вылетает и не хочет дальше ни работать, ни исправлять ошибки.

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

    Reply
  20. verad

    Обработка не работает в SQL-базе, превышение максимального количества таблиц в запросе. Пробовала отметить в дереве метаданных хотя бы просто один! вид документа — получаю эту ошибку. Если бы работала — была бы очень полезная вещь.

    Reply
  21. nalivai-chai

    (19) Oli29,

    Oli29 пишет:

    База БУ8 оказалась сбойной «Файл базы данных поврежден…»

    Маловероятно, что проблема вообще в битых ссылках.

    Может Вам поможет утилита от 1С: «C:Program Files1cv828.2.14.528inchdbfl.exe»(19) Oli29,

    Reply
  22. nalivai-chai

    (20) verad,

    verad пишет:

    Обработка не работает в SQL-базе

    …. не для всех объектов метаданных.

    Остается только, выгрузить в файловую базу.

    Reply
  23. Oli29

    (21)

    Спасибо, действительно помогла эта утилитка, и база исправилась.

    Reply
  24. vetalm

    задумка и подход мегакул но результат не удовлетворяет.

    Моя история: необходимо почистить регистры накопления без регистраторов — отмечаю необходимые регистры, ищу битые ссылки, находит приблизительно 10000 записей, отмечаю объекты по реквизиту регистратор, удаляю. Со списка вродь как все удаляются но когда смотрю список регистров накопления битые записи всеже на месте. Обработкой «регистрация изменений» объектов для РИБ смотрю то в нужном регистре появляются 10000 записей измененных. Запускаю на обработке «поиск битых ссылок» вновь поиск опять находятся все теже 10000 записей. Вобщем чевойто то тут не все доделано.

    Reply
  25. tormozit

    Интересное творение

    Reply
  26. Klondaik

    Спасибо за обработку. Удобный интерфейс, функционал понравился..Вобщем почистил базу нормально:)

    Reply
  27. pvlunegov

    Спасибо за обработку! Поставил плюс. Некогда было разбираться с другими возможностями.

    В своей базе заменил кучу битых ссылок на пустые. Быстро и эффективно.

    Но!

    Автора прошу в модуле объекта добавить строку:

    »

    Перем глОбщиеЗначения;

    »

    Иначе ругань при открытии обработки.

    А так все вроде работает.

    Reply
  28. Жолтокнижниг

    Заочно +1, завтра буду тестить если что отпишусь

    Reply
  29. Sairys

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

    Reply
  30. Tur_gad

    Обработка супер. Но нельзя ли такуюже под 8,1 скинуть пожалуйста ОЧЕНЬ НАДО!!!!!!!!!!!

    Reply
  31. nalivai-chai

    (31) Tur_gad,

    Нет платформы 8.1 под рукой.

    Но…

    Вы можете попробовать сделать обратную конвертацию следующим путем:

    — добавить обработку в конфигурацию на платформе 8.2,

    — затем скопировать её в буфер (Ctrl+C),

    — открыть любую конфигурацию на платформе 8.1

    — выбрать ветку обработки и вставить обработку из буфера (Ctrl+V).

    Должно получиться.

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

    Reply
  32. marku

    Хорошо бы вставить ОбработкаПрерыванияПользователя()

    Reply
  33. 1977

    Под УТ11 не запустилось!!!

    Reply
  34. nalivai-chai

    (34) 1977, запустите в «обычном приложении», не в «управляемом».

    Reply
  35. 1977

    Значить не пойдет в Ут11.

    Reply
  36. nalivai-chai

    (36) 1977, да почему же не пойдет?

    Подскажу: Открываете конфигуратор. Главное меню -> Отладка -> Начало отладки -> Толстый клиент (обычное приложение): начать отладку.

    Откроется ваша УТ11 с обычным инетрфейсом. Без всяких интерфейсов и красивостей. Но зато можно запустить обработку с обычным интерфесом.

    Reply
  37. 1977

    Там такого нету!!

    Reply
  38. nalivai-chai

    (38) 1977, В конфигураторе нужно установить параметры:

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

    тогда будет доступен запуск отладки в режиме » Толстый клиент (обычное приложение)».

    Reply
  39. Jon2011

    У меня всегда вызывало сомнение, при запуске стандартной ТИ, что выбирать — удаление битых ссылок или восстановление объекта, потому как нужное выбирать приходится в темную. А здесь всегда можно посмотреть с чем связана ссылка и окончательно решить, что с ней делать.

    Безусловно полезная обработка. Однозначно плюс.

    Reply
  40. teplova

    Здравствуйте, у меня БП 8.2. Есть битая ссылка. Но Ваша обработка ее не находит почему-то.

    Reply
  41. nalivai-chai

    (41) teplova, скажите, пожалуйста, с какими объектами связана битая ссылка (тип битой ссылки, в объекте какого типа она обнаружена)?

    Reply
  42. echo77

    Отличная вещь! Правда пока почему-то не получилось подключиться к внешней базе

    Если бы можно было бы сохранять настройки — было бы вообще здорово!

    Reply
  43. echo77

    (0) Ошибка при попытке установить пометки на удаление для объектов с битыми ссылками в табличных частях.

    Reply
  44. stupid01

    Спасибо!

    Помогло

    Reply
  45. ls300

    Огромное спасибо, за обработку! Не было времени выдумывать свою, а восстанавливать надо..

    Reply
  46. Synoecium

    Хорошая обработка, вот только при выполнении «Очистка регистров» выдало следующую ошибку:

    Возникла ошибка при обработке объекта: РегистрСведений.АналитикаУчетаПрочихЗатрат

    {ВнешняяОбработка.ПоискБитыхСсылок.МодульОбъекта(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

    Reply
  47. nalivai-chai

    (47) Synoecium, если база не совсем огромная, то можно равзернуть как файловую. На файловой такой ошибки не должно быть. Вообще есть обработка, где решена эта проблема, в ближайшие дни постараюсь выложить.

    Reply
  48. insurgut

    Отличная обработка! Не раз выручала 🙂

    Reply
  49. shmellevich

    Спасибо, автору, за золотые руки!!! Только что, очень помогло восстановить все битые Товары и к ним подчиненные справочники )))

    Reply
  50. 7OH

    Поддерживаю идею о сохранении настроек.

    И после поиска логично переходить в список найденного.

    Reply
  51. gaglo

    Обработка хороша. Богатые возможности, добрый интерфейс. И ещё — она работает! (Это главное!)

    НО, конечно, есть мелкие замечания — возможно, на будущее…

    Запускал в конфигурации, где нет общей формы ХодВыполненияОбработкиДанных. Выборка, конечно, идет, но без всякой индикации, и (по-моему) постоянная обработка исключений в этом случае затянула цикл вдвое. Наверное, стоило бы индикацию процесса сделать через Состояние — скромненько, но и быстренько.

    Стоило бы добавить еще возможность отбора типов битых ссылок для поиска — скажем, только ссылки на единицы измерения. При решении уже известных проблем время бы экономилось.

    Ну и, конечно, то, что в (51) — поддерживаю.

    Reply
  52. tanselja

    Классная обработка!!!!!

    Reply
  53. васисубатор

    Пользователи теперь запрещенная переменная (при подключении к копии базы) — изменил, в остальном классная штука

    Reply
  54. pavelyar

    А в УФ работает обработка?

    Reply
  55. nalivai-chai

    нет(

    Reply
  56. DAnry

    Спасибо автору! Очень полезная вещь. Пользуюсь. Вот только не всегда коректно работает удаление объектов с битыми ссылками.

    Форма.Форма.Форма(864)}: Помилка при виклику методу контексту (Удалить)

    НаборЗаписей.Удалить(ЗаписьДляУдаления);

    через:

    Неприпустиме значення параметру (параметр номер ‘1’)

    Reply
  57. nalivai-chai

    (57) DAnry, спасибо за ошибку, постараюсь устранить.

    Reply
  58. IgorXml

    (21) Спасибо, это помогло — утилита от 1С: «C:Program Files1cv828.2.XXX.XXXinchdbfl.exe»

    Обновляли файловую базу на БП 2.0.64 и прервали.

    Обработкой делать пробовал, но ничего не получилось:

    Reply
  59. GERMANTAGIL

    Обработка понравилась и действительно работает.

    Ситуация была следующая

    Суть проблемы — удалили участок на предприятии

    идем в справочники-предприятие-подразделения

    открывается хрень

    слева — структура предприятия

    справа — подразделения организаций

    дак вот — то что слева я поднял встало вроде нормально

    причем поднимал обработкой — GUID

    https://w1c.ru/epf-1.html

    А вот справа — GUID работает некорректно

    орет что нужен «владелец»

    ну дак вот давай я думать как обмануть адрес вроде есть а к чему привязать

    Вопрос был вроде простой как по битой ссылке найти все записи —

    хотя я и понимал что мне нужно восстановить только один обьект.

    Поискал в Инете ну все не то — все не так работает.

    подразделения организаций (когда созадется подразделение) — GUID работает некорректно

    система 1С — орет что нужен «владелец»

    Ваша обработка отработала корректно — восстановила все 168 документов

    Но у меня вопрос автору —

    1. хотелось бы обработку которая по <Объект не найден> (84:893f00215aecf30a11e0760ca6c900fd) искала бы все вхождения

    чтобы можно было представлять какие документы справочники и т.д. были «задеты» (в архивах может другое количество записей)

    2. Нетривиальная задача восстановления элемента номенклатуры вместе с единицами измерения (те хотелось бы вариант при воссстановлении элемента номенклатуры подвязывалась еденица измерения правильная — иначе придется бродить по множеству документов)

    в ручную я вроде нашел вариант который работает а вот обработок подобного типа вообще не видел

    Еще раз большое спасибо

    Reply
  60. insurgut

    (60) GERMANTAGIL, системе пофиг на владельца, если «ОбменДанными.Загрузка = Истина;» 🙂

    Reply
  61. mvmish

    Не работает обработка!

    Reply
  62. nalivai-chai

    (62) mvmish, а подробнее? 🙂

    Reply
  63. madway

    Отличный инструмент. Нужно было восстановить битые ссылки в одной из РИБ. Соединился с другой базой , вытащил данные.

    Одно пожелание, сделайте возможность выбора компонента для соединения Com82 или com83.

    Reply
  64. CheBurator

    Непонятно, можно ли битую ссылку заменить другой, нормальной?

    Reply
  65. tormozit

    (65) В ИР из аналогичного инструмента «Поиск битых ссылок» можно передать битую ссылку в подбор и обработку объектов, добавить правильную ссылку, передать обе ссылки в обработку «Объединить ссылки».

    Reply
  66. CheBurator

    (66) учтем

    Reply
  67. fixin

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

    Я удалил физически лишнюю номенклатуру, остались битые ссылки в документах «Установка цен».

    Только я доработал, чтобы меняло не на пустую ссылку, а на один определенный элемент с указанным именем. Если его не находит, ссылку не обрабатывает, пропускает.

    Выкладываю версию, автор, добавьте в свою, если посчитаете нужным.

    Reply
  68. ZhokhovM

    Вопрос, может ли эта обработка найти битые ссылка в отчетах? Например, в отборе характеристики в отчете аптеки стоит «<Объект не найден> (480:aee70015e9b8c48d11e01fecb9c33de3)».

    Reply
  69. CratosX

    К сожалению в моём случае не помогло — есть строки ТЧ документов, у которых отсутствуют объекты-владельцы

    Reply
  70. tormozit

    (70) А инструментами разработчика видными на скриншоте тоже не помогло?

    Reply
  71. CratosX

    (71) не помогало (обход данных выбирал все три варианта — строки, объекты и ключи объектов), либо выдавало ошибку, либо ничего не удалялось.

    И да, на самом деле не надо удалять эти строки, т.к. есть ещё и движения у этих битых документов.

    Решение описал тут http://forum.infostart.ru/forum86/topic164787/message1740846/#message1740846 , три способа:

    1. Берём ирПортативный, ищем все строки ТЧ, находим битые ссылки вида <Объект не найден> (196:8ca0d017c29aac7511e6e6bb9148a258), берём обработку GUID82_w1c.epf, создаём документ, записываем, лезем в его движения — оттуда пытаемся вычислить реквизиты документа (например дату, время, склад и т.п.), вносим их в документ — записываем.

    2. В ТиИ обязательно выбираем режим «Создавать объекты». После исправления придётся редактировать эти добавленные элементы.

    3. Если есть архив базы, возможно перенести переносом (ВыгрузкаЗагрузкаДанныхXML) — с применением обработки GUID82_w1c.epf можно в архиве найти нужные объекты по ссылкам.

    Reply
  72. tormozit

    (72)

    1. Не помогло сделать что? Ты не описал задачу.

    2. Зачем брать обработку GUID82_w1c.epf ? Прямо из списка строк для обработки можно открыть редактор объекта БД для битой ссылки и записать (создать новый) объект с идентификатором битой ссылки.

    Reply
  73. CratosX

    (73)

    1. удалить ссылки на несуществующий объект (в данном случае — строки ТЧ)

    2. Не знал, спасибо. Пошёл читать полное описание ир…

    Reply
  74. tormozit

    (74)

    Reply
  75. maxx

    Помогла эта штука. В Бухгалтерии после обмена из УНФ через какое-то время оказалось битые ссылки, трудно сказать сейчас причин (то ли сбой базы, то ли обмен так работает..) . Но нашёл эти ссылки, выгрузил отчет по битым ссылкам и на основе его написал свою обработку в УНФ для регистрациии в план обмена указанных битых ссылок (кое-где не совпадают название метаданных, но это не проблема).

    Reply
  76. maxf

    Вылезает ошибка. Вроде не должно быть нехватки памяти при обработке всего лишь корректировок долга.

    Reply
  77. nalivai-chai

    (77) Причины могут совершенно разные:

    * Настройки СУБД

    * Объем памяти ОС с СУБД

    * Объем записей в таблице корректировок и связанных таблицах, которые участвуют в запросе

    * Ограничен ли поиск битых ссылок по реквизитам

    * Какие типы входят в состав типов реквизитов, в которых выполняется поиск битых ссылок

    * Возможно запрос не оптимальный сформировался

    Reply
  78. sapervodichka

    также удобная штука по восстановлению битых ссылок https://infostart.ru/public/888694/

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *