mirror of
https://github.com/netology-code/1c-homeworks.git
synced 2024-11-24 08:02:20 +02:00
Update homework-5-5.md
This commit is contained in:
parent
fb3bdf2eb4
commit
7307672577
@ -28,83 +28,7 @@
|
||||
|
||||
Процедура ОбработкаПроведения(Отказ, РежимПроведения)
|
||||
|
||||
```bsl
|
||||
// 1. Получение запросом данных документа
|
||||
Запрос = Новый Запрос;
|
||||
Запрос.МенеджерВременныхТаблиц = Новый МенеджерВременныхТаблиц;
|
||||
Запрос.Текст =
|
||||
"ВЫБРАТЬ
|
||||
| Товары.Номенклатура КАК Номенклатура,
|
||||
| СУММА(Товары.Количество) КАК Количество
|
||||
|ПОМЕСТИТЬ Товары
|
||||
|ИЗ
|
||||
| Документ.Реализация.Товары КАК Товары
|
||||
|ГДЕ
|
||||
| Товары.Ссылка = &Ссылка
|
||||
|
|
||||
|СГРУППИРОВАТЬ ПО
|
||||
| Товары.Номенклатура
|
||||
|
|
||||
|ИНДЕКСИРОВАТЬ ПО
|
||||
| Номенклатура
|
||||
|;
|
||||
|
|
||||
|////////////////////////////////////////////////////////////////////////////////
|
||||
|ВЫБРАТЬ
|
||||
| Товары.Номенклатура КАК Номенклатура,
|
||||
| Товары.Количество КАК Количество
|
||||
|ИЗ
|
||||
| Товары КАК Товары";
|
||||
Запрос.УстановитьПараметр("Ссылка", Ссылка);
|
||||
РезультатЗапроса = Запрос.Выполнить();
|
||||
|
||||
// 2. Формирование движений-расход регистра
|
||||
Движения.ДвиженияТовара.Очистить();
|
||||
ВыборкаТовары = РезультатЗапроса.Выбрать();
|
||||
Пока ВыборкаТовары.Следующий() Цикл
|
||||
Движение = Движения.ДвиженияТовара.ДобавитьРасход();
|
||||
Движение.Период = Дата;
|
||||
Движение.Номенклатура = ВыборкаТовары.Номенклатура;
|
||||
Движение.Количество = ВыборкаТовары.Количество;
|
||||
КонецЦикла;
|
||||
|
||||
// 3. Запись движений в БД
|
||||
Движения.ДвиженияТовара.Записывать = Истина;
|
||||
Движения.Записать();
|
||||
|
||||
// 4. Запрос, получающий отрицательные остатки из регистра
|
||||
Запрос.Текст =
|
||||
"ВЫБРАТЬ
|
||||
| Остатки.Номенклатура КАК Номенклатура,
|
||||
| ПРЕДСТАВЛЕНИЕССЫЛКИ(Остатки.Номенклатура) КАК НоменклатураПредставление,
|
||||
| -Остатки.КоличествоОстаток КАК Дефецит
|
||||
|ИЗ
|
||||
| РегистрНакопления.ДвиженияТовара.Остатки(
|
||||
| &МоментВремени,
|
||||
| Номенклатура В
|
||||
| (ВЫБРАТЬ
|
||||
| Товары.Номенклатура КАК Номенклатура
|
||||
| ИЗ
|
||||
| Товары КАК Товары)) КАК Остатки
|
||||
|ГДЕ
|
||||
| Остатки.КоличествоОстаток < 0";
|
||||
|
||||
ГраницаКонтроля = Новый Граница(МоментВремени(), ВидГраницы.Включая);
|
||||
Запрос.УстановитьПараметр("МоментВремени", ГраницаКонтроля);
|
||||
РезультатЗапроса = Запрос.Выполнить();
|
||||
|
||||
// 5. Вывод сообщений о недостатке товаров
|
||||
Если Не РезультатЗапроса.Пустой() Тогда
|
||||
Отказ = Истина;
|
||||
ВыборкаОшибки = РезультатЗапроса.Выбрать();
|
||||
Пока ВыборкаОшибки.Следующий() Цикл
|
||||
Сообщение = Новый СообщениеПользователю;
|
||||
Сообщение.Текст = "Товара "+ВыборкаОшибки.НоменклатураПредставление+" недостаточно в количестве "+ВыборкаОшибки.Дефецит+" шт.";
|
||||
Сообщение.Сообщить();
|
||||
КонецЦикла;
|
||||
КонецЕсли;
|
||||
|
||||
КонецПроцедуры
|
||||
```РегистрыНакопления.ДвижениеТоваров.Остатки()
|
||||
```
|
||||
## Задача 2 Создать отчет СКД "Остатки товаров"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user