Поле объекта недоступно для записи значение 1с. Почему появляется эта ошибка

Для начинающих разработчиков 1С 8.3 трудно понять, почему же они так часто получают ошибку — Поле объекта недоступно для записи 1С (РабочаяДата, Код, Таблица, Номер, Дата и т.д.) . Разберемся, почему эта ошибка может появятся, и как с ней бороться.

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

Если ошибка возникла после обновления конфигурации 1С 8.2 или 8.3 , скорее всего, Вам необходимо до последней актуальной версии.

Получите 267 видеоуроков по 1С бесплатно:

Если Вы начинающий программист 1С

Если говорить в общем, то Вы пытаетесь в программном коде изменить данные, которые не имеете права менять. Рассмотрим конкретные случаи:

Меняй объект, а не ссылку

Хит-парад причин появления этой ошибки возглавляет попытка присвоения ссылке элемента новых атрибутов. Делают это обычно примерно так:

Петров = Справочники. ФизическиеЛица. НайтиПоНаименованию("Петров Иван" ) ; Петров. НомерПаспорта = "2156363" ;

И вот на этом моменте новичок получает ошибку — Поле объекта недоступно для записи 1С.

Следует уяснить: изменять свойства и реквизиты возможно только объекта. В данном случае переменная «Петров» содержит в себе т.н. «ссылку» — уникальный идентификатор в базе данных, с помощью которого система поддерживает уникальность. А то, что нам доступно «по точке» (Петров.НомерПаспорта), — это просто удобство 1С предприятия, и на самом деле любая «точка» — это еще один запрос к базе данных.

Правильное решение задачи:

ПетровСсылка = Справочники. ФизическиеЛица. НайтиПоНаименованию("Петров Иван" ) ; ПетровОбъект = ПетровСсылка. ПолучитьОбъект() ; ПетровОбъект. НомерПаспорта = "2156363" ; ПетровОбъект. Записать() ;

Попытка изменить системные поля

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

  • номер строки табличной части;
  • использование ТекущаяСтрока, вместо ТекущиеДанные;
  • и так далее.

При первых начинания неопытных разработчиков 1С 8.3 достаточно часто возникает такая проблема: Поле объекта недоступно для записи 1С. Необходимо разобраться, почему же может возникать подобная проблемы и что следует делать, чтобы она больше не беспокоила пользователя.

В случае если вы НЕ программист 1С, а обычный пользователь.

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

Полезная информация для начинающих программистов 1С.

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

  • Следует менять объект, а не ссылку! Самым распространенным объяснением появления данной ошибки следует считать изменение свойств ссылки, а не объекта. Как правило, это выглядит так:

Сидоров = Справочник.ФизЛицо.ПоискПоНаименованию("Сидоров Федор") ;

Сидоров.НомерУдостоверенияЛичности = "6574928" ;

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

У вас есть вопрос, нужна помощь консультанта?

Начинающие программисты 1С достаточно часто видят перед собой сообщение об ошибке недоступности поля объекта при записи. Существует всего три пути появления этой ошибки, но на практике с ней встречаются достаточно часто, поэтому разработчику надо знать, как исправить ситуацию. Поняв один раз причины появления сообщения системы «Поле объекта недоступно для записи», вы перестанете получать его раз и навсегда.

Почему появляется эта ошибка?

Если вы простой пользователь и видите перед собой такую ошибку, то вряд ли вы сможете с ней справиться самостоятельно. Проблема не в ваших действиях, а в ошибке в коде программы. Чтобы исправить ее, необходимо проанализировать алгоритмы. Поэтому, увидев ошибку «Поле недоступно для записи», сообщите разработчику и ждите его указаний. Если в штате вашей компании нет программистов 1С, то к вам на помощь придут сторонние специалисты.

Разработчики выделяют 3 распространенные причины появления окна с ошибкой:

Попытка изменения ссылки, а не объекта. В системе 1С существуют определенные правила, и одно из них гласит: «Изменять можно только объекты». Проблема в том, что ссылка – просто адрес объекта в базе данных, созданный для уникальности. Важно понять разницу между ссылкой и объектом, потому что при некоторых операциях с ними результат будет одинаковый.

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

НЕПРАВИЛЬНЫЙ КОД: СсылкаНаНоменклатуру = Справочники.Номенклатура.НайтиПоНаименованию("Сметана 25%"); СсылкаНаНоменклатуру.Наименование = "Сметана Вологодская 25%"; СсылкаНаНоменклатуру.Записать() ; ПРАВИЛЬНЫЙ КОД: СсылкаНаНоменклатуру = Справочники.Номенклатура.НайтиПоНаименованию("Сметана 25%"); НоменклатураОбъект = СсылкаНаНоменклатуру.ПолучитьОбъект(); НоменклатураОбъект.Наименование = "Сметана Вологодская 25%"; НоменклатураОбъект.Записать();

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

ДокументОбъект = Документы.ПоступлениеТоваровУслуг.НайтиПоНомеру("000000003").ПолучитьОбъект(); Для каждого строчка из ДокументОбъект.Товары цикл строчка.НомерСтроки = 2; КонецЦикла; ДокументОбъект.Записать();

Еще одной причиной появления подобной ошибки является обновления. 1С выпускает их достаточно часто и для конфигураций, и для платформ. Проблема в том, что далеко не все изменения подвергаются тщательному тестированию, и пользователи невольно выполняют эту работу. Именно поэтому рекомендуется пользоваться тестовой базой для обновления, на которой проверять работоспособность нового релиза 1С, сопоставлять на ней значение и параметры.

Что делать, если после обновления вы все-таки не можете работать, наблюдая ошибку недоступности поля объекта для записи?

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

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

// Попутно заполним поле ФИО объекта, если необходимоЕсли Не ЗначениеЗаполнено(Объект.ФИО) Тогда СтруктураФИО = ФизическиеЛицаКлиентСервер.ФамилияИмяОтчество(ТРег(Объект.Наименование)); НаименованиеФизЛица = СокрЛП(СтруктураФИО.Фамилия + "" "" + СтруктураФИО.Имя + "" "" + СтруктураФИО.Отчество); Объект.ФИО = НаименованиеФизЛица; Объект.Записать();КонецЕсли;//На всякий случай проверим, есть записи в регистре для текущего элементаДанныеФЛ = РегистрыСведений.ФИОФизическихЛиц.СрезПоследних(ТекущаяДатаСеанса(), Новый Структура(""ФизическоеЛицо"", Ссылка));Если ДанныеФЛ.Количество() = 0 Тогда //Заполнение регистра ФИО физических лиц для бухгалтерии предприятия 3.0 СтруктураФИО = ФизическиеЛицаКлиентСервер.ФамилияИмяОтчество(ТРег(Объект.ФИО)); Период =?(ЗначениеЗаполнено(Объект.ДатаРождения), Объект.ДатаРождения, Дата(1900, 1, 1)); СтруктураФИО.Вставить(""Период"", Период); СтруктураФИО.Вставить(""ФизическоеЛицо"", Ссылка); Набор = РегистрыСведений.ФИОФизическихЛиц.СоздатьНаборЗаписей(); Набор.Отбор.ФизическоеЛицо.Установить(Ссылка); Запись = Набор.Добавить(); ЗаполнитьЗначенияСвойств(Запись, СтруктураФИО); Набор.Записать(); КонецЕсли; Регистр нормально заполнится, если наименования элементов справочника или поле ФИО заполнены упорядоченно, то есть в формате Фамилия Имя Отчество. С вас сто рублей на телефон в профиле в качестве благодарности. // ЭКСПОРТИРУЕМЫЕ ПРОЦЕДУРЫ И ФУНКЦИИПроцедура вЗагрузитьОбработки(ДоступныеОбработки, ВыбранныеОбработки) Экспорт Формы = ЭтотОбъект.Метаданные().Формы; Для каждого Форма из Формы Цикл Если Форма.Имя = ""ПодборИОбработка"" ИЛИ Форма.Имя = ""ФормаНастроек"" ИЛИ Форма.Имя = ""ШаблонОбработки"" Тогда Продолжить; КонецЕсли; НайденнаяСтрока = ДоступныеОбработки.Строки.Найти(Форма.Имя, ""ИмяФормы""); Если НЕ НайденнаяСтрока = Неопределено Тогда Если НЕ НайденнаяСтрока.Обработка = Форма.Синоним Тогда НайденнаяСтрока.Обработка = Форма.Синоним; КонецЕсли; Если НЕ ЭтотОбъект.ПолучитьФорму(Форма.Имя).мИспользоватьНастройки Тогда НайденнаяСтрока.Строки.Очистить(); КонецЕсли; Продолжить; КонецЕсли; НоваяОбработка = ДоступныеОбработки.Строки.Добавить(); НоваяОбработка.Обработка = Форма.Синоним; НоваяОбработка.ИмяФормы = Форма.Имя; КонецЦикла; МассивДляУдаления = Новый Массив; Для каждого ДоступнаяОбработка из ДоступныеОбработки.Строки Цикл Если Формы.Найти(ДоступнаяОбработка.ИмяФормы) = Неопределено Тогда МассивДляУдаления.Добавить(ДоступнаяОбработка); КонецЕсли; КонецЦикла; Для Индекс = 0 по МассивДляУдаления.Количество() - 1 Цикл ДоступныеОбработки.Строки.Удалить(МассивДляУдаления[Индекс]); КонецЦикла; МассивДляУдаления.Очистить(); Для каждого ВыбраннаяОбработка из ВыбранныеОбработки Цикл Если ВыбраннаяОбработка.СтрокаДоступнойОбработки = Неопределено Тогда МассивДляУдаления.Добавить(ВыбраннаяОбработка); Иначе Если ВыбраннаяОбработка.СтрокаДоступнойОбработки.Родитель = Неопределено Тогда Если ДоступныеОбработки.Строки.Найти(ВыбраннаяОбработка.СтрокаДоступнойОбработки.ИмяФормы, ""ИмяФормы"") = Неопределено Тогда МассивДляУдаления.Добавить(ВыбраннаяОбработка); КонецЕсли; Иначе Если ДоступныеОбработки.Строки.Найти(ВыбраннаяОбработка.СтрокаДоступнойОбработки.Родитель.ИмяФормы, ""ИмяФормы"") = Неопределено Тогда МассивДляУдаления.Добавить(ВыбраннаяОбработка); КонецЕсли; КонецЕсли; КонецЕсли; КонецЦикла; Для Индекс = 0 по МассивДляУдаления.Количество() - 1 Цикл ВыбранныеОбработки.Удалить(МассивДляУдаления[Индекс]); КонецЦикла;КонецПроцедуры // вЗагрузитьОбработки() 1С:Предприятие 8.2 (8.2.18.61) Толстый клиент конфа не стандартная.

Вот еще: вот решил попробовать замену значений в справочнике в табличной части, надо отобрать и просто удалить значение (заменить на пустое) и вот после отбора: ""{Форма.ПодборИОбработка.Форма(991)}: Ошибка при вызове метода контекста (Вывести): Ошибка вывода результата: Ошибка при выводе результата: Ошибка получения данных: Ошибка создания набора данных ""НаборДанныхЗапроса"": Ошибка при исполнении запроса набора данных: {(223, 31)}: Неверные параметры в операции сравнения. Нельзя сравнивать поля неограниченной длины и поля несовместимых типов. ТаблицаСсылок.Ссылка.Рационы >= &П"".


Похожие темы Тема Автор Форум Ответов Посл. Сообщение Важная: Обработка (управляемое и обычное приложение, обмен данными УТ 10.3/10.2 - БП 3.0) Предназначена для переноса документов и справочников из базы УТ 10.3/УТ 10.2 в базу БП 3.0 без использования планов обмена.:arrow: Поддерживаемые релизы (для платформ 1С Предприятия 8.1, 8.2, 8.3): Управление торговлей: 79 Сб 09 Сен, 2017 00:22 Обработка (управляемое приложение) Позволяет упростить процесс отладки и тестирования внешних обработок заполнения, в том числе табличных частей, или создания связанных объектов (ввода на основании) для конфигураций 1С: Предприятия 8.2/8.3, разработанных 39 Вт 18 Апр, 2017 19:43 Обработка (управляемое и обычное приложение) Предназначена для просмотра/изменения ролей (прав доступа) пользователей информационной базы как в режиме управляемого, так и обычного приложения без привязки к конкретной конфигурации. Для группового изменения ролей 8 Чт 02 Фев, 2017 19:45 Обработка (управляемое и обычное приложение), обмен данными Назначение: универсальная обработка для регистрации, отмены регистрации изменений (управления регистрацией) в планах обменов, мониторинга состояния обмена данными как в режиме управляемого, так и обычного приложения без 28 Пт 18 Авг, 2017 01:06 Универсальный механизм контроля заполнения реквизитов объектов в режиме предприятия (обычное приложе Универсальный механизм контроля заполнения реквизитов (контроль незаполненных реквизитов) шапки и табличных частей объектов конфигурации (справочников, документов, бизнес-процессов, задач, планов обмена, планов видов 15 Чт 09 Июл, 2015 15:29.

Поместил кнопку в форме списка справочника, написал код: Процедура ДействияФормыНомера(Кнопка) Выборка = Справочники.СписокУпражнений.Выбрать(); Пока Выборка.Следующий() Цикл Если Выборка.Родитель.Наименование = "" Тогда Если Выборка.ГруппаМышц. 14 окт 10, 17:20 Ответить| Цитировать Сообщить модератору. Re: Поле объекта недоступно для записи. 1c8.2 Справочник Сотрудники Модуль формы элемента. Процедура ПриОткрытии() Если не ЭтоНовый() Тогда.


При работе с 1С довольно часто может появляться сообщение об ошибке « Поле объекта недоступно для записи». Рассмотрим, какие действия могут привести к ней, и как её можно устранить. Причины возникновения ошибки К появлению системного окна с этой ошибкой может привести 6 факторов: Попытка изменения значений в полях, смена которых бессмысленна; Ошибка в коде; Попытка изменения системных полей; Недостаточно прав на изменение; Устаревшая конфигурация 1С; В управляемой форме используется элемент и реквизит с одним именем.

Попытка изменения значений в полях, смена которых бессмысленна Например, в программе происходит попытка замены ссылки, а не объекта. Но сделать этого невозможно. Если изменить ссылку, то, во-первых, она будет ссылаться на несуществующий объект (в никуда), во-вторых, нужный объект по ней вы больше не найдёте. Пример неправильного фрагмента кода: Иванов = Справочники.ФизическиеЛица.НайтиПоНаименованию(«Иванов Петр»); Иванов.НомерПаспорта = «2175353»; И при вводе последней строчки появляется ошибка «Поле объекта недоступно для записи». Причина в том, что происходит попытка редактирования свойств или реквизитов ссылки. В указанном примере параметру «НомерПаспорта» вы пытаетесь задать определённое значение. Но эти данные можно менять только у объекта.

В данном примере «Иванов» - это именно ссылка, которая предназначена для чтения. По ней человек идентифицируется в базе данных. Во второй строчке указана «точка» - «Иванов.НомерПаспорта». Но это также не объект, потому что при обращении к «точке» выполняется все тот же запрос к базе данных. Сделано это для удобства использования 1С. Как исправить ошибку?

Чтобы сообщение « Поле объекта недоступно для записи» больше не появлялось, нужно прописать следующее: ИвановСсылка = Справочники.ФизическиеЛица.НайтиПоНаименованию(«Иванов Петр»); ИвановОбъект = ИвановСсылка.ПолучитьОбъект(); ИвановОбъект.НомерПаспорта = «2175353»; ИвановОбъект.Записать(); Теперь по ссылке выполняется обращение к объекту, а затем уже он редактируется. После этого объект записывается, то есть фиксируется его новое состояние. Ошибка в коде Возможно причина в том, что программист, который работал с текущей конфигурацией 1С, допустил ошибку при доработке. Тогда исправить её сможет также только специалист. Желательно, чтобы это был именно тот человек, который изначально настраивал 1С.

Попытка изменения системных полей Пользователь пытается редактировать те данные, на замену которых он не имеет прав. Например, номер строки в таблице, установка «ТекущаяСтрока» вместо «ТекущиеДанные» и т. Иногда ошибка возникает из-за простой невнимательности. Если обращаться к правильным полям – ошибка появляться не будет. Недостаточно прав на изменение Иногда поле, которое пытается изменить пользователь, доступно только для чтения. Это связано с правами на объекты конкретного пользователя. Чтобы устранить возникающую ошибку, необходимо проанализировать права на конкретный объект и либо разрешить пользователю доступ к соответствующему полю (на запись), либо вообще исключить поле (или целый объект) из рассмотрения.

Устаревшая конфигурация 1С Иногда ошибка « Поле объекта недоступно для записи» появляется при обновлении 1С. Чтобы убрать её, нужно обновиться до самой свежей версии платформы. Устранить ошибку обычно не сложно и сделать это может сам пользователь. Если же серьёзно нарушена конфигурация 1С, исправить положение сможет только специалист. В управляемой форме используется элемент и реквизит с одним именем Достаточно редко ошибка « Поле объекта недоступно для записи» появляется при совпадении имён реквизита и элемента управляемой формы.

Чтобы устранить ошибку, необходимо явно прописать обращение к реквизиту или элементу формы. К примеру, в форме 1С имеется реквизит с именем «Сумма».

С таким же именем на форме находится элемент «Сумма».