Содержание:
1. Ошибка при установке значения атрибута контекста
2. Ошибка при получении значения атрибута контекста
Одной из наиболее частых ошибок исполнения кода 1С являются ошибки, связанные с установкой реквизита либо получением реквизита через точку, либо ошибка при вызове функции или процедуры через точку. Все данные объекты являются атрибутами информационных объектов-владельцев, к которым они принадлежат. Рассмотрим примеры таких ошибок и причины их возникновения.
1. Ошибка при установке значения атрибута контекста
Ошибка при установке значения атрибута контекста говорит нам о невозможности присвоить выбранное значение определенному атрибуту информационного объекта. Вызвано это либо несовпадением типа атрибута и присваиваемого ей значения, отсутствием возможности присвоить значение выбранному атрибуту, так как его можно только читать, но не записывать в него, отсутствием прав у текущего пользователя на запись значений в данный атрибут. Например, в реквизит «ДатаДокумента» с типом «Дата» пытаемся записать строку, в реквизит с типом данных ссылки на документ пытаемся записать не ссылку, а объект, полученный по ссылке, что невозможно из-за несоответствия типов, что приводит к ошибке установки значения атрибута.
Другой пример – проходя циклом выборку запроса, пытаемся в колонку выборки записать значение, что невозможно, так как значения выборки запроса можно только считывать, а для того, чтобы можно было полученные из запроса данные изменять в коде, нужно пользоваться не выборкой, а выгружать результат запроса в таблицу значений, в таком случае в цикле по ней можно будет менять значения в колонках, но только на значения, соответствующие типу колонки. Либо у пользователя, под которым выполняется код, нет прав на изменение даты документа, при попытке записать в данный реквизит новую дату, будет выведено сообщение об ошибке установке значения, но в причине будет указано отсутствие прав у пользователя.
2. Ошибка при получении значения атрибута контекста
Ошибка при получении значения атрибута контекста указывает на невозможность прочитать значение атрибута объекта в силу его отсутствия, либо отсутствия прав на его чтение. Например, обращение к несуществующему реквизиту объекта, несуществующему полю выборки из запроса, несуществующему свойству элемента формы и т.п. Так же как пример можно рассмотреть получение текущего пользователя из параметров сеанса — если данный параметр сеанса не установлен, то тоже будет выведена ошибка получения значения атрибута контекста, но в причине будет указана попытка получения неинициализированного значения параметра сеанса.
При возникновении данных ошибок значения атрибута в 1Св первую очередь следует проверить существование атрибута, к которому обращаются, затем проверить совпадение типов значений атрибута и присваиваемого ему значения, затем уже проверить права на установку либо чтение значения. Проверить, является ли дело в правах либо дать права на действия с атрибутом, можно, установив привилегированный режим для совершения действия с данным атрибутом, прописав перед строчкой с ошибкой УстановитьПривилегированныйРежим(Истина), после строчки — УстановитьПривилегированныйРежим(Ложь).
Специалист компании «Кодерлайн»
Александр Суворов
Heltarion 2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
||||
1 |
||||
02.12.2011, 11:18. Показов 9104. Ответов 11 Метки нет (Все метки)
Добрый день! ТПП — «табличное поле правил», в ней уже занесены некотрые значения из XML Код процедуры:
0 |
308 / 308 / 1 Регистрация: 16.01.2011 Сообщений: 1,073 |
|
02.12.2011, 11:32 |
2 |
СохранитьНажатие(Элемент) это событие формы
1 |
2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
|
02.12.2011, 11:56 [ТС] |
3 |
СохранитьНажатие(Элемент) это событие формы В МодулеОбъекта создал функцию «Процедура СохранитьВЭксель(ТПП) Экспорт»
0 |
308 / 308 / 1 Регистрация: 16.01.2011 Сообщений: 1,073 |
|
02.12.2011, 12:10 |
4 |
процедуру ИнициализацияЭкселя() тоже закинь в модуль объекта
1 |
2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
|
02.12.2011, 12:19 [ТС] |
5 |
Да я именно так и сделал, просто забыл упомянуть, ТПП нужна в противном случае он не понимает что это за переменная Добавлено через 4 минуты Так работает, но если я поставлю Дело в том что «стр.НоменклатураБазы» — это справочник ссылка, если у нее текстовый тип то программа глотает и записывает.
0 |
19 / 18 / 1 Регистрация: 15.11.2011 Сообщений: 54 |
|
02.12.2011, 12:22 |
6 |
чет вы мудрено делаете.
1 |
2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
|
02.12.2011, 12:28 [ТС] |
7 |
В данный момент ему не нравится присваемое значение к ячейке экселя (если я правильно понимаю сообщение «Ошибка при установке значения атрибута контекста (Value)» ) Причем если тип значения строка, то он его получает без вопросо, если тип значения СправочникССсылка, то он руегается на «Ошибка при установке значения атрибута контекста (Value)». Я просто не понимаю как обратиться к такому типу переменных чтобы получить значение типа строка.
0 |
19 / 18 / 1 Регистрация: 15.11.2011 Сообщений: 54 |
|
02.12.2011, 12:30 |
8 |
а принудительно все значения в текст перевести нельзя?
1 |
308 / 308 / 1 Регистрация: 16.01.2011 Сообщений: 1,073 |
|
02.12.2011, 12:30 |
9 |
стр.НоменклатураБазы.Наименование например
1 |
2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
|
02.12.2011, 12:32 [ТС] |
10 |
стр.НоменклатураБазы — это уже есть наименование интересующего меня поля (имя столбца), в некотрых случаях можно писать: стр.НоменклатураБазы.Значение, но это нетот случай Добавлено через 56 секунд
0 |
308 / 308 / 1 Регистрация: 16.01.2011 Сообщений: 1,073 |
|
02.12.2011, 12:34 |
11 |
значение из Excel?
1 |
Heltarion 2 / 2 / 0 Регистрация: 21.11.2011 Сообщений: 57 |
||||
02.12.2011, 12:43 [ТС] |
12 |
|||
Рабочий код:
0 |
Попытка
// Загрузка Microsoft Excel
Состояние(«Загрузка Microsoft Excel…»);
Excel = Новый COMОбъект(«Excel.Application»);
Исключение
Сообщить(«Ошибка при загрузке Microsoft Excel.» + Символы.ПС + ОписаниеОшибки(), СтатусСообщения.Внимание);
Возврат;
КонецПопытки;
Excel.WorkBooks.Add();
row=1;
Для Каждого Элемент Из Результат Цикл
Excel.Cells(row, 1).Value = Элемент.Организация;
Excel.Cells(row, 2).Value = Элемент.Субконто1;
Excel.Cells(row, 3).Value = Элемент.Субконто2;
Excel.Cells(row, 4).Value = Элемент.Счет;
Excel.Cells(row, 5).Value = Элемент.СуммаОстатокДт;
Excel.Cells(row, 6).Value = Элемент.СуммаОстатокКт;
row = row+1;
КонецЦикла;
Здравствуйте!
Задача: Передать из 1С в хранимую процедуру на MSSQLSERVER параметр табличного типа?
в С# вот так замечательно передается параметр табличного типа и все работает:
DataTable table = new DataTable(); //Далее заполняем таблицу, подключаемся SqlConnection connection1 = new SqlConnection(@»Data Source= …….
SqlParameter p = new SqlParameter(«@Name», SqlDbType.Structured);
p.Value = table; //и ……..
В 1С вот так передаются обычные параметры:
Подключение = Новый COMОбъект(«ADODB.Connection»);
*******
*******
П1 = «Какое то значение для параметра обычных типов»;
Тип = «Числовое значение указывающее на тип»
СтрДл1 = СтрДлина(П1);
P1 = Command.CreateParameter(«@Param», Тип, 1, СтрДл1, П1);
Command.Parameters.Append(P1);
Не могу найти какое значение нужно указать в качестве Type в Command.CreateParameter для 1С!
Или может причина в другом?
В ADO есть такой тип?
Может существует драгой подход?
указывал
П1 = Command.CreateParameter();
П1.Name = «@Name»;
П1.Type = «SqlDbType.Structured»; //Именно в кавычках
П1.Value = table; // table — это ТаблицаЗначений 1С
Выдает ошибку:
Ошибка при установке значения атрибута контекста (Value)
П1.Value = table;
по причине:
Произошла исключительная ситуация (ADODB.Parameter): Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт друг с другом.
В обоих случаях table заполнена одинаковыми данными
Передавать таблицу на сервер при помощи нескольких тысяч ИНСЕРТОВ накладно!
Заранее благодарю за помощь!
-
Изменено
29 мая 2012 г. 14:34
После подключения расширения4.89e (и то же самое для 4.91e), при наличии в конфигурации БСП версии 2.4.6.78, при попыткевхода любого пользователя без административных прав возникает ошибка:
Платформа: 1С:Предприятие 8.3 (8.3.12.1685)
Ошибки:
———————————————————————————
26.04.2019 10:21:38
{Справочник.ВерсииРасширений.МодульМенеджера(130)}: Ошибка
при получении значения атрибута контекста (ВерсияРасширений)
ВерсияРасширений
= ПараметрыСеанса.ВерсияРасширений;
по причине:
{Справочник.ВерсииРасширений.МодульМенеджера(458)}: Ошибка
при вызове метода контекста (Записать)
Объект.Записать();
по причине:
Ошибка при выполнении обработчика — ‘ПередЗаписью’
по причине:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
Попытка получения неинициализированного значения параметра
сеанса
Под полными правами вбазу заходит. Но при попытке открыть любой элемент справочника возникает ошибка:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
{Справочник.ВерсииРасширений.МодульМенеджера(458)}: Ошибка
при вызове метода контекста (Записать)
Объект.Записать();
по причине:
Ошибка при выполнении обработчика — ‘ПередЗаписью’
по причине:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
Попытка получения неинициализированного значения параметра
сеанса
Пришлось пока что отключатьрасширение через конфигуратор. Дальше попробовал удалить записи справочника
Версии расширений и РС Идентификаторы объектов версий расширений, после чего
запустить базу с параметром /С ЗапуститьОбновлениеИнформационнойБазы. Теперь в
базу заходит, но при попытке открыть элемент справочника следующая ошибка:
Ошибки:
———————————————————————————
26.04.2019 11:46:37
Переполнение стека встроенного языка на сервере
по причине:
Справочник.нсиКонтрагенты.Форма.ФормаЭлемента.Форма : 26 :
ВерсионированиеОбъектов.ПриСозданииНаСервере(ЭтотОбъект);
ОбщийМодуль.ВерсионированиеОбъектов.Модуль : 106 : Объект =
ОбщегоНазначения.ИдентификаторОбъектаМетаданных(ПолноеИмяМетаданных);
ОбщийМодуль.ОбщегоНазначения.Модуль : 3181 : Возврат
Справочники.ИдентификаторыОбъектовМетаданных.ИдентификаторОбъектаМетаданных(ОписаниеОбъектаМетаданных);
Справочник.ИдентификаторыОбъектовМетаданных.МодульМенеджера
: 612 : Возврат
СтандартныеПодсистемыПовтИсп.ИдентификаторОбъектаМетаданныхПоПолномуИмени(ПолноеИмяОбъектаМетаданных);
Инфо:
—
Платформа: 8.3.12.1685
Режим БД: клиент-серверный
Конфигурация. Название: 1С:MDM Управление нормативно справочной информацией, редакция 2.0 (2.0.4.1)
Конфигурация. Основной режим запуска: Управляемое приложение
Конфигурация. Вариант встроенного языка: Русский
Конфигурация. Режим совместимости: Версия8_3_10
Конфигурация. Версия БСП: 2.4.6.78
Инструменты разработчика. Версия: Портативные 4.89p
Инструменты разработчика. Объекты на сервере: Да
Инструменты разработчика. Серверный модуль: Да
Клиент. ОС: Windows x86 Microsoft Windows 7 version 6.1 Service Pack 1 (Build 7601)
Клиент. Приложение: Обычное приложение 32б
Клиент. От имени администратора Windows: Нет
Клиент. Текущий язык системы: ru
Сервер. ОС: Windows x86-64 Microsoft Windows 8.1 version 6.3 (Build 9600)
Добавлено (26.04.2019, 12:01)
———————————————
В общем, похоже, что несколько запусков обработки БСП ОбновлениеВспомогательныхДанных.epf помогло. Если ещё возникнут проблемы, напишу.