forum.bitel.ru
http://forum.bitel.ru/

Цена тарифа.
http://forum.bitel.ru/viewtopic.php?f=22&t=10354
Страница 1 из 1

Автор:  filin [ 01 апр 2015, 18:14 ]
Заголовок сообщения:  Цена тарифа.

Всем привет, нужно в xsl вывести цену тарифного плана, сам тариф я узнаю через contract/tariff/@tariff_plan

Автор:  stark [ 01 апр 2015, 18:57 ]
Заголовок сообщения:  Re: Цена тарифа.

а где вывести ? цена в каком модуле? Да и цену в общем случае не так просто получить - это надо составить запрос, заполнить его параметрами, отправить в тарификатор и получить ответ.

Автор:  dimOn [ 02 апр 2015, 10:23 ]
Заголовок сообщения:  Re: Цена тарифа.

Что означает вообще "цена тарифного плана"?

Автор:  Phricker [ 02 апр 2015, 10:55 ]
Заголовок сообщения:  Re: Цена тарифа.

Она означает, что в большинстве своем сейчас предлагаются тарифные планы аля "Безлимит 1Мб/с за 15 рублей в месяц".
Сейчас чем проще тем лучше.
ИМХО у ТСа точно так же и он хочет получить именно эти 15 рублей модуля Абонплат

Автор:  Phricker [ 02 апр 2015, 10:56 ]
Заголовок сообщения:  Re: Цена тарифа.

ТС, проще всего писать цену прямо в названии тарифа и выводить название.

Автор:  stark [ 02 апр 2015, 11:03 ]
Заголовок сообщения:  Re: Цена тарифа.

Phricker писал(а):
Она означает, что в большинстве своем сейчас предлагаются тарифные планы аля "Безлимит 1Мб/с за 15 рублей в месяц".
Сейчас чем проще тем лучше.
ИМХО у ТСа точно так же и он хочет получить именно эти 15 рублей модуля Абонплат


Может уберем дерево и сделаем его плоским , услуга -цена? :)

Автор:  stark [ 02 апр 2015, 11:04 ]
Заголовок сообщения:  Re: Цена тарифа.

Вообще их xsl можно вызывать bsh-код, а 6.2 еще и динамический код. Там можно сделать что угодно, хоть тарифный запрос отправить.

Автор:  Phricker [ 02 апр 2015, 12:15 ]
Заголовок сообщения:  Re: Цена тарифа.

stark писал(а):
Может уберем дерево и сделаем его плоским , услуга -цена? :)

ЕМНИМС обещали то ли поле в тарифе, в котором можно написать цену, которую в дальнейшем можно получить запросом, то ли класс, который будет по договору делать предполагаемое начисление и выводить цену. :P

Автор:  stark [ 02 апр 2015, 12:17 ]
Заголовок сообщения:  Re: Цена тарифа.

Phricker писал(а):
stark писал(а):
Может уберем дерево и сделаем его плоским , услуга -цена? :)

ЕМНИМС обещали то ли поле в тарифе, в котором можно написать цену, которую в дальнейшем можно получить запросом, то ли класс, который будет по договору делать предполагаемое начисление и выводить цену. :P


Не гибко это как-то

Автор:  vkulakov [ 02 апр 2015, 12:54 ]
Заголовок сообщения:  Re: Цена тарифа.

У нас цена тарифа получается из базы с помощью хитрого SQL-запроса. Нужно это для отображения в ЛК и изредка в отчётах. Структура запроса сильно зависит от структуры самих тарифных планов, но по образу и подобию можно переделать под себя. Если интересно, могу выложить код запросов - в XSL, вроде, можно вставлять и выполнять SQL запросы.

Что-то автор потерялся совсем :).

Автор:  filin [ 02 апр 2015, 14:13 ]
Заголовок сообщения:  Re: Цена тарифа.

vkulakov писал(а):
У нас цена тарифа получается из базы с помощью хитрого SQL-запроса. Нужно это для отображения в ЛК и изредка в отчётах. Структура запроса сильно зависит от структуры самих тарифных планов, но по образу и подобию можно переделать под себя. Если интересно, могу выложить код запросов - в XSL, вроде, можно вставлять и выполнять SQL запросы.

Что-то автор потерялся совсем :).

Было бы здорово!

В общем есть обычный тариф 1 мегабит в секунду за 1000 рублей в месяц
и в договоре который мы печатаем с биллинга через xsl нужно указать название тарифа и его цену

Автор:  dimOn [ 02 апр 2015, 14:17 ]
Заголовок сообщения:  Re: Цена тарифа.

Проще всего вам сейчас забить choose в самом шаблоне и выводить нужные цены согласно каждому id тарифа.
Остальные способы много сложнее. Т.к. в общем случае задача решается непросто.

ну и цены у вас :lupa:

Автор:  Phricker [ 02 апр 2015, 14:23 ]
Заголовок сообщения:  Re: Цена тарифа.

dimOn писал(а):
Проще всего вам сейчас забить choose в самом шаблоне и выводить нужные цены согласно каждому id тарифа.

Окей :D
Код:
# mysql -uroot -p -e "select count(*) from bgbilling.tariff_plan;"
+----------+
| count(*) |
+----------+
|      650 |
+----------+

Автор:  dimOn [ 02 апр 2015, 14:31 ]
Заголовок сообщения:  Re: Цена тарифа.

ну чо все используются чтоле и все такие простые и нужные?

Автор:  Phricker [ 02 апр 2015, 14:34 ]
Заголовок сообщения:  Re: Цена тарифа.

По районам различаются только скоростями )
90% выглядят так как то так
Изображение

Автор:  vkulakov [ 02 апр 2015, 14:57 ]
Заголовок сообщения:  Re: Цена тарифа.

Вот SQL-запрос, который получает соответствие тариф-цена:
Код:
SELECT
   p.id AS tariffId,
   p.title AS tariffTitle,
   MAX(CONVERT(IF(LOCATE('type', n.data) < LOCATE('%', n.data), SUBSTRING(n.data FROM LOCATE('%', n.data) +  6), SUBSTRING(n.data, 6, LOCATE('%', n.data) - 6)), DECIMAL(10,2))) AS tariffCost
FROM
   bgbilling.tariff_plan p
   LEFT JOIN bgbilling.module_tariff_tree t ON p.tree_id = t.tree_id AND t.mid = 2
   LEFT JOIN bgbilling.mtree_node n ON n.mtree_id = t.id AND n.type = 'month_cost'
GROUP BY
   p.id;

t.mid = 2 - код кодуля npay, исправить под себя,
n.type = 'month_cost' - подозреваю, у вас тоже самое, в случае чего исправить под себя.

Я делаю группировку, т. к. у нас в тарифах есть ветки для тарифных опций и я тупо получаю максимальную стоимость из всех веток - для наших тарифов работает.

Автор:  vkulakov [ 02 апр 2015, 14:59 ]
Заголовок сообщения:  Re: Цена тарифа.

Главное, при изменении тарифов потом не забыть, что есть запрос чувствительный к структуре тарифа.

Автор:  vkulakov [ 03 апр 2015, 12:41 ]
Заголовок сообщения:  Re: Цена тарифа.

filin, может напишите здесь результат своих изысканий? А то какая-то незавершённость чувствуется...

Страница 1 из 1 Часовой пояс: UTC + 5 часов [ Летнее время ]
Powered by phpBB® Forum Software © phpBB Group
http://www.phpbb.com/