helpf.pro
Регистрация
 +41 
Распечатать

Как изменить запись регистра сведений?

Код 1C v 8.х
 НаборЗаписей = РегистрыСведений.НумерацияДоговоров.СоздатьНаборЗаписей();  			
			НаборЗаписей.Отбор.Период.Установить(НачалоГода(Дата));
			НаборЗаписей.Отбор.Организация.Установить(Организация);
			НаборЗаписей.Прочитать();
			Если НаборЗаписей.Количество() = 0 Тогда
				НовыйНомер = НаборЗаписей.Добавить();
				НовыйНомер.Организация = Организация;
				НовыйНомер.Период = НачалоГода(Дата);
				НовыйНомер.Номер = 2; ном=1;
			ИначеЕсли НаборЗаписей.Количество() = 1 Тогда
				НовыйНомер = НаборЗаписей[0];
				ном = НовыйНомер.Номер;
				НовыйНомер.Номер = ном+1;
			КонецЕсли;
			НаборЗаписей.Записать();
			Номер = Организация.Префикс +  "-" + Ном + "/" + Строка(Прав(Год(ТекущаяДата()),2));
   


Код 1C v 8.х
 //Установить курс Валюты USD
КурсыВалют = РегистрыСведений.КурсыВалют;
НаборКурсов = КурсыВалют.СоздатьНаборЗаписей();
Доллар = Справочники.Валюты.НайтиПоНаименованию("USD");
НаборКурсов.Отбор.Валюта.Установить(Доллар);
НаборКурсов.Отбор.Период.Установить(НачалоДня(ТекущаяДата()));
НаборКурсов.Прочитать();
Если НаборКурсов.Количество() = 0 Тогда
    НовыйКурс = НаборКурсов.Добавить();
    НовыйКурс.Валюта = Доллар;
    НовыйКурс.Период = ТекущаяДата();
ИначеЕсли НаборКурсов.Количество() = 1 Тогда
    НовыйКурс = НаборКурсов[0];
Иначе
    Предупреждение("Курс валюты задается один раз в день.", 60);
    Возврат;
КонецЕсли;
НовыйКурс.Курс = 31.44;
НовыйКурс.Кратность = 1;
НаборКурсов.Записать();   


Код 1C v 8.х
  //В регистр были ошибочно записаны штрихкоды. 
// Нужно по заданным Номенклатуре (Товар) и Характеристике (ХарактеристикаТовара) найти эту запись и заменить там штрихкод.
  Запрос = Новый Запрос;
    Запрос.Текст = 
    "ВЫБРАТЬ
    |    ШтрихкодыНоменклатуры.Штрихкод КАК Штрихкод
    |ИЗ
    |    РегистрСведений.ШтрихкодыНоменклатуры КАК ШтрихкодыНоменклатуры
    |ГДЕ
    |    ШтрихкодыНоменклатуры.Номенклатура = &Номенклатура И
    |    ШтрихкодыНоменклатуры.Характеристика = &Характеристика";
    
    Запрос.УстановитьПараметр("Номенклатура", Товар);
    Запрос.УстановитьПараметр("Характеристика", ХарактеристикаТовара);

    Выборка = Запрос.Выполнить().Выбрать();
        Если НЕ Выборка.Следующий() Тогда
        ТекЗапись = РегистрыСведений.ШтрихкодыНоменклатуры.СоздатьМенеджерЗаписи();
        ТекЗапись.Номенклатура = Товар;
        Если ЗначениеЗаполнено(ХарактеристикаТовара) Тогда
             ТекЗапись.Характеристика = ХарактеристикаТовара;
        Иначе    
             ТекЗапись.Характеристика = Справочники.ХарактеристикиНоменклатуры.ПустаяСсылка();
        КонецЕсли;
        ТекЗапись.Штрихкод  = ?(ПустаяСтрока(ШтрихКод),РегистрыСведений.ШтрихкодыНоменклатуры.СформироватьШтрихкодEAN13(), Штрихкод);
        Попытка
            ТекЗапись.Записать();
        Исключение
        КонецПопытки;
    Иначе
        НайденныйШтрихкод = Выборка.Штрихкод;
         ТекЗапись = РегистрыСведений.ШтрихкодыНоменклатуры.СоздатьМенеджерЗаписи();
        ТекЗапись.Штрихкод = НайденныйШтрихкод;
        ТекЗапись.Прочитать();
        
        ТекЗапись.Штрихкод  = Штрихкод;
        Попытка
            ТекЗапись.Записать();
        Исключение
        КонецПопытки;

    КонецЕсли;   
Разместил:   Версии: | 8.x | 8.2 УП |  Дата:   Прочитано: 339302
 +41 
Распечатать
Возможно, вас также заинтересует
Как заполнить табличную часть формы программно? 8
Нужно по кнопке Заполнить - сформировать данные для заполнения табличных частей и заполнить их. Форма имеет вид: Рядом с кнопкой Записать и закрыть добавлена кнопка Заполнить документ , код ее команды: // Код заполнения ТЧ НаСервере П
17 правил для составления оптимального ЗАПРОСа к данным базы 1С 53
Для формирования и выполнения запросов к таблицам базы данных в платформе 1С используется специальный объект языка программирования Запрос . Создается этот объект вызовом конструкции Новый Запрос . Запрос удобно использовать, когда требуется получ
Cообщение: "Не удалось удалить чеки ККМ!" 2
Пользователь с правами Администратор ККМ проводит Закрытие кассовой смены (Z). Выходит сообщение: " Не удалось удалить чеки ККМ!" ФР печатает Z -отчет, но Отчет о рознчничных продажах не формируется. Необходимо дать роли Администратор ККМ прав
Microsift Visual C++ Runtime Library Program ...1cv77s.exe abnormal program termination 0
При запуске 1С 7.7 выдает сообщение: Microsift Visual C++ Runtime Library Program C:Program Files1Cv77BIN1cv77s.exe abnormal program termination Вариант 1. Обычно это происходит, когда повреждается файл регистрации. Точнее, когда не дописывает
Блокировка записей, невозможно изменить или удалить из регистра. Конфликт блокировок MS SQL + 1C 4
При попытке удалить запись из регистра сведений - получаю ошибку: она заблокирована, ошибка блокировок и т.д. Отключил всех пользователей, перезапустил сервер, пробую удалить - опять ошибка блокировки :( Путем тестов было вяснено, что проблема
Посмотреть все результаты поиска похожих
Комментарии
DJ_Serega
04.03.2013 09:42Комментарий: 2
DJ_Serega
Это было к последнему листингу *02
DJ_Serega
04.03.2013 09:41Комментарий: 1
DJ_Serega
A тут случайно не нужно вот так писать?
Код 1C v 8.х
 
Иначе
        Выборка.Следующий;
        НайденныйШтрихкод = Выборка.Штрихкод;   
Вы не можете отправить комментарий анонимно, пожалуйста войдите или зарегистрируйтесь.
Загрузка... Дождитесь завершения!