URL: https://www.opennet.me/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID9
Нить номер: 1232
[ Назад ]

Исходное сообщение
"Хранение данных биллинга."

Отправлено SergD , 27-Дек-02 10:05 
  Добрый день.

   Подскажите как сделать такую штуку. В общем у меня есть некий скрипт обсчета остатка ресурса пользователя. Алгоритм его работы довольно прост. На вход подается момент входа юзера в систему и длительность сеанса. Этот сеанс просматривается и в зависимости от того в какой из наперед заданных диапазонов суток попал этот сеанс из ресурса юзера вычитается некоторая величина. Сейчас это написано через множественные if{} ... elsif{} ... else{}, что не есть хорошо.
   Более того сейчас возникла необходимость периодически менять тарифную сетку. Так вот, что бы не переписывать каждый раз эту функцию, как правильно организовать хранение и отбор подобных данных на Perl?
   Желательно также учитывать момент ввода этих данных и учет выходных и праздников.

  
    


Содержание

Сообщения в этом обсуждении
"RE: Хранение данных биллинга."
Отправлено roma , 28-Дек-02 21:33 
мы имеем юзеров, тарифные планы и собственно сами тарифы. К юзеру привязываем тарифный план. План содержит тарифы - от одного и до скольких угодно. Каждый тариф действует в определенное время (диапазон времени) определенного дня. Вот собственно и вся схема. На вход по-прежнему идет ID юзера, время сеанса и его продолжительность. По юзеру находим план, по времени находим тариф. Все.
Данные (планы, тарифы, юзера) хранятся где-угодно, если все более менее серьезно, то в БД.

"RE: Хранение данных биллинга."
Отправлено SergD , 29-Дек-02 11:18 
>мы имеем юзеров, тарифные планы и собственно сами тарифы. К юзеру привязываем
>тарифный план. План содержит тарифы - от одного и до скольких
>угодно. Каждый тариф действует в определенное время (диапазон времени) определенного дня.
>Вот собственно и вся схема. На вход по-прежнему идет ID юзера,
>время сеанса и его продолжительность. По юзеру находим план, по времени
>находим тариф. Все.
>Данные (планы, тарифы, юзера) хранятся где-угодно, если все более менее серьезно, то
>в БД.


    Спасибо, попробую так и сделать.