30.06.2021 Аскер Жансуев 35860
Поиск битых ссылок в 1С

Содержание:

  1. Выборка объектов с помощью запроса
  2. Использование объектной модели
  3. Поиск подстроки 1С «Объект не найден» в представлении ссылки

   

Трудно найти человека, который при работе с информационными базами данных на платформе 1С более или менее продолжительное время, ни разу не столкнулся с "битыми" ссылками в 1С, которые содержат поля таблиц баз данных (пресловутый текст в 1С «Объект не найден» c уникальным идентификатором отсутствующего объекта в поле со ссылкой на отсутствующий объект информационной базы). Причинами возникновения таких ситуаций могут быть выполнение удаления объектов информационных баз без контроля ссылочной целостности, аварийные завершения работы информационных баз, ошибки при обменах данными и т.д.

 

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

 

Существуют несколько способов выявления "битых" ссылок в 1С в таблицах информационной базы.  


1.    Выборка объектов с помощью запроса

 

Первый способ: выборка объектов информационной базы с "битыми" ссылками в 1С с помощью запроса.

 

ТекстЗапроса =

    "ВЫБРАТЬ

    |       ПеремещениеТоваров.Ссылка КАК Ссылка

    |ИЗ

    |       Документ.ПеремещениеТоваров КАК ПеремещениеТоваров

    |ГДЕ

    |       НЕ ПеремещениеТоваров.СкладОтравитель ЕСТЬ NULL

    |       И ПеремещениеТоваров.СкладОтравитель.Ссылка ЕСТЬ NULL".

 

В данном случае мы с помощью запроса производим поиск документов «Перемещение товаров», у которых "битая" ссылка на склад-отправитель. Для этого в условии отбора убеждаемся, что ссылка на склад-отправитель в принципе не пустая(часть условия "ГДЕ": "НЕ ПеремещениеТоваров.СкладОтравитель ЕСТЬ NULL") и, если это так, то проверяем ссылку на "битость"(часть условия "ГДЕ": "ПеремещениеТоваров.СкладОтравитель.Ссылка ЕСТЬ NULL").

 

Во второй части условия "ГДЕ" ("ПеремещениеТоваров.СкладОтравитель.Ссылка ЕСТЬ NULL") вместо "Ссылка" можно использовать другие реквизиты склада-отправителя, например, "Код" ("ПеремещениеТоваров.СкладОтравитель.Код ЕСТЬ NULL") – в таком случае мы также сможем отобрать перемещения с "битыми" ссылками на склад-отправитель.

 

Следует оговорить ситуацию, когда нужно произвести выборку объектов с битыми ссылками в 1С, но при этом поле объекта, в котором возможна "битая" ссылка, имеет составной тип, а нам требуется найти "битые" ссылки только определенного типа. Например, если в нашем случае склад-отправитель имеет составной тип "Склады" + "Подразделения организаций", а нам нужно отобрать только перемещения с "битыми" складами-отправителями типа "Подразделения организаций", в текст нашего запроса в условие "ГДЕ" добавится часть "ПеремещениеТоваров.СкладОтравитель ССЫЛКА Справочник.ПодрадзделенияОрганизаций". Запрос примет следующий вид:

  

"ВЫБРАТЬ

    |       ПеремещениеТоваров.Ссылка КАК Ссылка

    |ИЗ

    |       Документ.ПеремещениеТоваров КАК ПеремещениеТоваров

    |ГДЕ

    |       ПеремещениеТоваров.СкладОтравитель ССЫЛКА Справочник.ПодрадзделенияОрганизаций

    |       И НЕ ПеремещениеТоваров.СкладОтравитель ЕСТЬ NULL

    |       И ПеремещениеТоваров.СкладОтравитель.Ссылка ЕСТЬ NULL".  


2.    Использование объектной модели

 

Второй способ: определение "битой" ссылки с использованием объектной модели данных 1С.

 

При данном способе для поиска "битых" ссылок используется метод ПолучитьОбъект() платформы 1С по ссылке на объект информационной базы, который возвращает «Неопределено» в случаях с "битыми" ссылками:

   

Если ЗначениеЗаполнено(ДокументПеремещения.СкладОтправитель) И (ДокументПеремещения.СкладОтправитель.ПолучитьОбъект() = Неопределено) Тогда

// Здесь выполняется требуемый код обработки найденного объекта с "битой" ссылкой.

КонецЕсли;

 

Если поле с "битой" ссылкой имеет составной тип, и нам необходимо выявлять только битые ссылки определенного типа, тогда, как и при первом случае, мы соответствующим способом модифицируем условие:

 

Если (ТипЗнч(Объект.СкладОтравитель) = Тип("СправочникСсылка.ПодрадзделенияОрганизаций")) И ЗначениеЗаполнено(ДокументПеремещения.СкладОтправитель) И (ДокументПеремещения.СкладОтправитель.ПолучитьОбъект() = Неопределено) Тогда

        // Здесь выполняется требуемый код обработки найденного объекта с "битой" ссылкой.

    КонецЕсли.  


3.    Поиск подстроки «Объект не найден» в представлении ссылки

 

Третий способ: поиск подстроки «Объект не найден» в представлении ссылки.

 

    Если СтрНайти(ДокументПеремещения.СкладОтправитель, "Объект не найден") > 0 Тогда

        // Здесь выполняется требуемый код обработки найденного объекта с "битой" ссылкой.

    КонецЕсли;

 

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


При это нужно быть аккуратным – используя в коде поиск "битых" ссылок по подстроке «Объект не найден», нужно учитывать, что подстрока "Объект не найден" в представлении "битой" ссылки может изменяться в зависимости от языка, используемого в "региональных установках информационной базы".


Специалист компании «Кодерлайн»

Аскер Жансуев

 

Наши проекты

Автоматизация контроля исполнительской дисциплины на базе ПП «1С:Документооборот 8 ПРОФ»
ООО «ФСК Лидер»

Отрасль:
Строительство и девелопмент

Внедренное типовое решение:
1С:Документооборот 8 ПРОФ

- Делопроизводство;
- Учет и хранение документов;
- Учет и контроль исполне...

АО «Аэроклуб»
АО «Аэроклуб»

Отрасль:
Услуги в области делового туризма

Внедренное типовое решение:
1С:Бухгалтерия 8 КОРП

Проведение серии интервью с руководством и ключевыми специалистами Разраб...

ПАО «АрселорМиттал Кривой Рог»
ПАО «АрселорМиттал Кривой Рог»

Отрасль:
Металлургическая промышленность

Внедренное типовое решение:
1С:Управление производственным предприятием для Украины

- Кадровый учет
- Расчет зарплаты
- Регламентированная отчетность
- Уч...

ООО «Стейдж Энтертейнмент Россия»
ООО «Стейдж Энтертейнмент Россия»

Отрасль:
Театральная деятельность

Внедренное типовое решение:
Платформа 1С:Предприятие 8

Реализован процесс трансформации данных бухгалтерского учета по РСБУ в дан...

Фирма 1С
Фирма 1С

Отрасль:

Внедренное типовое решение:
1С:Документооборот

- Подготовка функциональной модели прикладного решения «1С:Документооборот...

Внедрение ПП "1С:Бухгалтерия 8 ПРОФ" в ООО "ДЕКОР"
ООО «ДЕКОР»

Отрасль:
Производство

Внедренное типовое решение:
1С:Бухгалтерия 8 ПРОФ

Управление персоналом и кадровый учет (HRM):
- Кадровый учет
- Расчет зарпл...

Фармацевтическое предприятие «Оболенское»
АО «Фармацевтическое предприятие «Оболенское»

Отрасль:
Фармацевтическая промышленность

Внедренное типовое решение:
1С:Управление производственным предприятием

- Адаптации блоков/подсистем планирования продаж, закупок и казначейства. ...

Внедрение блоков в 1С:Комплексная автоматизация 8
ООО «Больцен Рус»

Отрасль:
Оптовая торговля

Внедренное типовое решение:
1С:Комплексная автоматизация

- Оперативный учет...

Внедрение «1С:Зарплата и управление персоналом 8 КОРП» в компании «ПБК»
ООО «Партнер Бухгалтер Консультант»

Отрасль:
Бухгалтерские услуги

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Интеграция продукта с базой данных оперативного учета Axapta;
- Доработка фу...

ООО «ТейблТок»
ООО «ТейблТок»

Отрасль:
Общественное питание и рестораны

Внедренное типовое решение:
1С:ТОИР Управление ремонтами и обслуживанием оборудования

Мониторинг и анализ ключевых показателей деятельности предприятия Управле...

Разработка функциональных требований к информсистеме на базе «1С:Управление холдингом 8»
ФГУП «СВЯЗЬ-безопасность»

Отрасль:
Охранные услуги

Внедренное типовое решение:
1С:Управление холдингом

- Зафиксировали процессы по блокам бухгалтерского, налогового учета, казнач...

ООО «Иви.ру»
ООО «Иви.ру»

Отрасль:
Медиаиндустрия

Внедренное типовое решение:
1С:Управление корпоративными финансами

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

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение