Время от времени приходится разрабатывать алгоритмы расчета с условными значениями, например:
Расчет скидки для по Объему продаж:
От 0 до 10 тыс.уп. – 1 %
От 10 тыс.уп. до 30 тыс.уп. – 2 %
От 30 тыс.уп. до 50 тыс.уп. – 3 %
От 50 тыс.уп. до 100 тыс.уп. – 4 %
Свыше 100 тыс.уп. – 5 %
Я называю такие условные значения Показателями. Если Показатели остаются неизменными, то иногда программисты расчет условного значения прописывают в коде, возможно отдельной функцией. Если же, в какой-то период времени, значение показателей может меняться, то рациональнее будет хранить эту информацию в регистре сведений и устанавливать изменения документом. Именно такой механизм я хочу предложить к рассмотрению. Кроме того, он это будет не какой-то конкретный Показатель, а возможность описания любых Показателей, подобных рассмотренному примеру.
В первую очередь рассмотрим справочник Показатели. Поле Наименование содержит наиболее полное описание Показателя. В поле Код я предлагаю использовать не числовое значение, а литерал, удобный для запоминания и, соответственно, использования. Конечно же, необходимо вести контроль уникальности значения поля Код. Поле Параметр – это единица измерения входящих величин. Так как эта единица носит чисто информационный смысл, чтобы пользователю было понятно с чем мы имеем дело, то нет необходимости задействовать справочник Единиц измерения и можно обойтись символьным значение. В данном случае это не принципиально. Аналогично поле Значение – это единица измерения полученного результата. Поля Параметр и Значение используются только для отображения в шапке Документа УстановкаПоказателей.
Документ УстановкаПоказателей служит для ввода информации Показателей. Выбор реквизита Показатели, устанавливают заголовки столбцов табличной части. При сохранении документа строки упорядочиваются по возрастанию Параметра.
Документ УстановкаПоказателей является регистратором для регистра сведений ТекущиеПоказатели.
По ссылке на справочник Показатели, числовой величине Параметр на необходимую дату актуальности данный регистр позволит на найти необходимое значение. Например, при помощи запроса:
ВЫБРАТЬ ПЕРВЫЕ 1
ТекущиеПоказателиСрезПоследних.Параметр КАК Параметр,
ТекущиеПоказателиСрезПоследних.Значение КАК Значение
ИЗ
РегистрСведений.ТекущиеПоказатели.СрезПоследних КАК ТекущиеПоказателиСрезПоследних
ГДЕ
ТекущиеПоказателиСрезПоследних.Показатели = &Показатели
И ТекущиеПоказателиСрезПоследних.Параметр <= &Параметр
УПОРЯДОЧИТЬ ПО
Параметр УБЫВ
А теперь простенький пример использования Показателей. Допустим есть у нас документ, в табличной части которого необходимо использование результата Показателей.
В поле Скидка значение рассчитывается исходя из значения поля Количество (то есть от объема продаж) и Показателей, регулирующих данную зависимость.
&НаКлиенте
Процедура ПродажиКоличествоПриИзменении(Элемент)
стр = Элементы.Продажи.ТекущиеДанные;
Если не стр = Неопределено тогда
стр.Скидка =ПолучитьЗначениеПоказателя("ОбСкидка", стр.Количество, Объект.Дата);
КонецЕсли;
КонецПроцедуры
&НаСервере
Функция ПолучитьЗначениеПоказателя(Показатель, Параметр, Дата)
лТекст = "
|ВЫБРАТЬ ПЕРВЫЕ 1
| ТекущиеПоказателиСрезПоследних.Значение КАК ЗначениеПараметра
|ИЗ
| РегистрСведений.ТекущиеПоказатели.СрезПоследних(&Дата, ) КАК ТекущиеПоказателиСрезПоследних
|ГДЕ
| ТекущиеПоказателиСрезПоследних.Показатели.Код = &Код
| И ТекущиеПоказателиСрезПоследних.Параметр <= &Параметр
|
|УПОРЯДОЧИТЬ ПО
| Параметр УБЫВ
|";
лЗапрос = Новый Запрос(лТекст);
лЗапрос.УстановитьПараметр("Код", Показатель);
лЗапрос.УстановитьПараметр("Параметр", Параметр);
Кстати, в функцию ПолучитьЗначениеПоказателя() первым параметром, в данном случае, передается не Ссылка на Показатели, а Код. Иногда это удобнее, особенно если использовать литерал вместо числового кода.
Функционал протестирован в 1С:Предприятие 8.3 (8.3.18.1208) Бухгалтерия предприятия КОРП, редакция 3.0 (3.0.46.19).