+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 93.29 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

Нетрадиционное использование Microsoft Reporting Services

31.01.2013 13:04
badun1

Исторически сложилось так, что MS SSRS выбирался руководством компаний в которых я работал/ю как средство построения корпоративной отчетности. Конечно-же, чаще всего он не выбирался, а доставался в комплекте с MS SQL Server'ом. А так как он уже есть, то его нужно использовать и чаще всего не по назначению, а как придется. Поэтому и приходилось использовать Reporting Services для не совсем тривиальных задач. Под катом несколько вариантов такого применения.

1. SSRS как GUI или "Сделай мне кнопочки"

Реализация SSRS через Action Property объекта. 
c переходом, в зависимости от требований либо на другой отчет(Go to report при необходимости, с передачей параметров), либо на закладку в текущем отчете(Go to bookmark), либо на ссылку(Go to URL). Рисование кнопочек - отдельная тема. В моем случае они эволюционировали:

  • от простого textbox 
  • до графика  с Properties -> Border -> Emboss и активной ссылкой в названии графика( Chart Title -> Action -> Go to Report)
  • и обратно до textbox 

Добавим кнопочкам проверку в лучших традициях продуктов о Microsoft "А вы уверены? Точно?" 
Так как по умолчанию SSRS этого не умеет, будем использовать javascript. Добавим в пункт Properties-> Action-> Go to URL строку: 
="javascript:var check=confirm('Do you really want to process all the data? \n \nPlease do not close the browser while executing.'); if (check == true) {window.open('http://localhost/Reportserver?%2fTarget_Report&rs:Command=Render','_self')}"
Что яваскрипт умеет в связке с SSRS можно найти в гугле( alert, User Prompt, confirmations, open new window, injections, пр). Да, Javascript не будет отрабатывать в Visual Studio, проверять работоспособность придется в браузере.
Так же присутствует специфическое решение - . По сути это тот же Action -> Go to Repoort -> Текущий отчет. Был использован изначально когда пользователь нажимал кнопочки быстрее чем данные генерировались. Но пользователь ленив, поэтому "Не хочу нажимать кнопочку, пусть само обновляется." Так появился

2. SSRS как Прогрессбар

Прогрессбаром будет служить обычный Bar Chart, слегка подкорректированный 

  • Добавляем Bar Chart, выбираем значения(Values),
  • задаем пределы оси значений (Horizontal Axis Properties Minimum=0, Maximum=1), значением заголовка выбираем значение Value, изменения которого и будет отображать наш прогрессбар. В моем случае это =format(Fields!_Значение_.Value,"p0")
  • Удаляем все ненужное(оси, названия, легенду),
  • задаем абсолютное значение области графика(Chart Area-> Position -> Custom Position меняем на 0,0,100,100 ),
  • ширину столбца (Chart Series->Custom Attributes->PointWidth делаем такой, чтобы 1 столбец заполнил всю область графика, в моем случае) PointWidth=2,
  • задаем ChartArea Border Solid, Black и Chart Border None и получаем примерно следующее:

Теперь задаем свойством отчета Report-> AutoRefresh минимально возможное значение автообновления до тех пор пока наш прогрессбар не доберется до 100%=IIF(Fields!_Значение_.Value <> 1,1,0)
Ну и наконец, добавляем из пункта 1 кнопочку Далее, которая будет видна (TextBox Properties -> Visibility) только после того как наш прогрессбар дойдет до 100% =IIF(Fields!_Значение_.Value <> 1,True,False)

3. SSRS как Онлайн монитор

В данном случае был использован обычный линейный график с автообновлением каждую секунду для отображения на большом экране (телевизоре) статистики загрузки колл-центра, кол-ва текущих звонков, агентов и пр.
Стоит заметить что генерация самого отчета SSRS должна быть многим менее 1 сек, т.е. отчет должен быть легким, иначе автообновление будет постоянно висеть на значке

4. SSRS как Интерфейс для постройки графиков

"Не могу построить в екселе Waterfall Chart, сделай что-нибудь."
В данном случае у пользователя вызывало затруднение построение графика типа Водопад (Waterfall Chart) в екселе 2007. В интернетах много вариаций на тему построения данного графика с помощью SSRS, если будет интересно, могу привести детальную пошаговую инструкцию.
Отличием данного примера было неограниченное количество начальных-промежуточных-конечных значений, которые не должны участвовать в агрегации.

Если тема будет интересна, могу добавить несколько примеров использования связки MS SQL Server + SSRS в качестве User driven ETL.

Ссылки по теме

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

На протяжении многих лет интернет-магазин предлагает товары и услуги, ориентированные на бизнес-пользователей и специалистов по информационным технологиям.

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

В нашем магазине вы можете приобрести лицензионное ПО выбрав необходимое из широкого спектра и ассортимента по самым доступным ценам. Наши менеджеры любезно помогут определиться с выбором ПО, которое необходимо именно вам. Также мы проводим учебные курсы. Мы приглашаем к сотрудничеству учебные центры, организаторов семинаров и бизнес-тренингов, преподавателей. Сфера сотрудничества - продвижение бизнес-тренингов и курсов обучения по информационным технологиям.



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года