|   |   | 
| 
 | Реализация кэшбэка | ☑ | ||
|---|---|---|---|---|
| 0
    
        prilforreal 27.11.17✎ 12:26 | 
        Пишу обработку для начисления кэшбэка. Принцип работы такой: раз в месяц будет запускаться, выбирать документы по этим контрагентам, считать сумму из этих доков, и начислять процент на баланс, пока пишу  код для расчета этого процента, но появилась проблема, запускаю обработку для проверки, жму выполнить, никакой реакции... смотрю отладчиком, доходит до цикла и завершает процедуру, помогите разобраться будьте добры)
 Процедура КнопкаВыполнитьНажатие(Кнопка) //{{КОНСТРУКТОР_ЗАПРОСА_С_ОБРАБОТКОЙ_РЕЗУЛЬТАТА // Данный фрагмент построен конструктором. // При повторном использовании конструктора, внесенные вручную изменения будут утеряны!!! ТабДок = Новый ТабличныйДокумент; Макет = ЭтотОбъект.ПолучитьМакет("Макет"); Запрос = Новый Запрос; Запрос.Текст = "ВЫБРАТЬ | ДилЗаказ.Дилер, | СУММА(ДилЗаказ.Сумма_Итог) КАК Сумма_Итог |ИЗ | Документ.ДилЗаказ КАК ДилЗаказ |ГДЕ | ДилЗаказ.Проведен = &Истина | И ДилЗаказ.Дилер.Кэшбэк = &Истина | И ДилЗаказ.Дата МЕЖДУ &НачПериода И &КонПериода | |СГРУППИРОВАТЬ ПО | ДилЗаказ.Дилер"; Запрос.УстановитьПараметр("Истина", Истина); Запрос.УстановитьПараметр("КонПериода", ТекущаяДата()); НачПериода = НачалоДня(ТекущаяДата()-86400); Запрос.УстановитьПараметр("НачПериода", НачПериода); РезультатЗапроса = Запрос.Выполнить(); ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); СуммаКБ=0; Пока ВыборкаДетальныеЗаписи.Следующий() Цикл СуммаКБ=(ВыборкаДетальныеЗаписи.Сумма_Итог/100)*6; Сообщить(СуммаКБ); КонецЦикла; //}}КОНСТРУКТОР_ЗАПРОСА_С_ОБРАБОТКОЙ_РЕЗУЛЬТАТА КонецПроцедуры | |||
| 1
    
        Numerus Mikhail 27.11.17✎ 12:28 | 
        Сообщить(РезультатЗапроса.Пустой());     | |||
| 2
    
        Джинн 27.11.17✎ 12:28 | 
        И что, по не выполненным заказам тоже откаты начисляете?     | |||
| 3
    
        Numerus Mikhail 27.11.17✎ 12:30 | 
        НачПериода = НачалоДня(ТекущаяДата()-86400);
 это не месяц, а день, если что. Возможно у вас нет документов за последний день | |||
| 4
    
        Рэйв 27.11.17✎ 12:31 | 
        (0)>>Реализация кэшбэка
 В цивилизованном мире это называется ретро-бонус:-) | |||
| 5
    
        prilforreal 27.11.17✎ 12:34 | 
        (2) Есть проверка на проведенные документы, если документ проведен, значит заказ выполнен) (3) Ух, точно, какой невнимательный я, сейчас исправлю и посмотрю) (4) Нууууу! Где цивилизация а где мы?))     | |||
| 6
    
        vde69 27.11.17✎ 12:37 | 
        что-либо начислять на основании документов (вне этого документа) - грубейшая методологическая ошибка.
 надо так 1. сделать новый регистр "УчитываемыеПродажи" 2. подписку на событие по документам где делаем проводки по этому регистру 3. уже на основании движений в этом регистре начисляем бонусы/откаты плюс такого подхода - можно часть документов отсторнировать по этому одному документу, или наоборот ввести начальные остатки... | |||
| 7
    
        wondkind 27.11.17✎ 12:46 | 
        &Истина - да, это сильно     | |||
| 8
    
        vde69 27.11.17✎ 12:51 | 
        еще один момент - при изменений в контрагенте реквизита "Кэшбэк" у тебя сразу начнет считать для всех документов.
 Так не делается... например мы до 1 января начисляли, потом с 1 января по 1 июля не начисляем а дальше опять начисляем... твоя схема такое не сможет реализовать... | |||
| 9
    
        Адинэснег 27.11.17✎ 13:11 | 
        (0)ты регистр накопления не думал под задачу сделать?
 помимо начисления, надо еще и списывать баланс | |||
| 10
    
        prilforreal 27.11.17✎ 14:55 | 
        (9) Кэшбэк только начисляет, есть регистр расчеты, в него и запишу, тз толкового не дали, так что думаю еще придется поплясать. (8) Как так для всех? Только для ДилЗаказа, в запросе же написано)     | |||
| 11
    
        prilforreal 27.11.17✎ 14:56 | 
        (8) Каждого пятого числа будет начислять:
 C 5ого ноября по 5 декабря, с 5 декабря по 5 января итд | |||
| 12
    
        Numerus Mikhail 27.11.17✎ 14:59 | 
        (11) Имеется в виду, что если вы подключили контрагента к кэшбеку 1 декабря, твоя система посчитает все документы за период с 5 ноября по 1 декабря тоже. Это, вероятнее всего, неверно.     | |||
| 13
    
        prilforreal 27.11.17✎ 15:27 | 
        (6) Спасибо, обработка будет создавать в цикле документ оплата, через который и будет происходить начисление. (12) Отличное замечание! Спасибо! Поработаю над этим!     | |||
| 14
    
        3achem 27.11.17✎ 16:44 | 
        (0) Устанавливай дату непосредственно, если не понимаешь как высчитывать её программно. Убери из запроса проверку на &Истина. 
 Это: ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); На это: ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать().Выгрузить(); Это Пока ВыборкаДетальныеЗаписи.Следующий() Цикл На это Для каждого НСтр ИЗ ВыборкаДетальныеЗаписи Цикл Отладчиком намного легче смотреть таблицу значения, не правда ли? И предварительно, чтобы понять, что у тебя возвращает запрос прогони его через консоль. Бонус: Это можно сделать в запросе: СуммаКБ=(ВыборкаДетальныеЗаписи.Сумма_Итог/100)*6; | |||
| 15
    
        3achem 27.11.17✎ 16:46 | 
        (14) И добавлю, правильно данные хранить в регистрах, чем обращаться к документам.     | 
 
 | Форум | Правила | Описание | Объявления | Секции | Поиск | Книга знаний | Вики-миста |