В BI Publisher есть довольно удобная возможность модульного создания шаблонов разметки. Если во всех ваших отчетах «шапка» и «подвал» одинаковы, то есть смысл вынести их в суб-шаблоны. А в самих отчетах оставить лишь ссылки на них. Преимущества очевидны.
Также суб-шаблоны могут быть полезны как хранилище XSL-функций (например, функции по преобразованию числа в представление прописью)
Все это прекрасно, но существует небольшое «ограничение». Якобы, данный метод работает только с абсолютными путями.
logo
22 дек. 2009 г.
6 дек. 2009 г.
BIEE: фильтр по рангу в таблице среза
Что если вы хотите фильтровать кол-во выводимых в Answer’е строк? Нет ничего проще – скажете вы – используйте функцию RANK.
Но как быть с таблицей среза?
Но как быть с таблицей среза?
Ярлыки:
BIEE,
dense_rank,
pivot,
rank
11 нояб. 2009 г.
BIEE: анализ системной статистики совместно с данными UsageTracking
Наверняка, вы пользовались формой просмотра текущих характеристик вашего приложения BIEE.
Зачастую данные, показываемые этой формой, интересны для анализа. Особенно в совокупности с данными, предоставляемыми UsageTacking.
Согласитесь, было бы интересно узнать какое количество физических соединений открыто в момент пиковой нагрузки на BI Server, а также какие именно логические запросы были запущены.
Зачастую данные, показываемые этой формой, интересны для анализа. Особенно в совокупности с данными, предоставляемыми UsageTacking.
Согласитесь, было бы интересно узнать какое количество физических соединений открыто в момент пиковой нагрузки на BI Server, а также какие именно логические запросы были запущены.
Ярлыки:
BIEE,
perfmon,
Usage Tracking
9 нояб. 2009 г.
BIEE: ошибка при использовании источниками XML и СУБД с ConnectionScript
При создании репозитория BIEE, содержащего обращения к физическим источникам – XML-файлам, а также обращения к СУБД, ни в коем случае не задавайте ConnectionScripts для ConnectionPool’ов к СУБД.
При генерировании «ансвера», содержащего обращения к СУБД и к XML, внутренняя реализация BIServer’а не очищает скрипты пула соединений при последовательном доступе к этим источникам.
Соответственно возникает малоинформативная ошибка [nQSError: 10058]
При генерировании «ансвера», содержащего обращения к СУБД и к XML, внутренняя реализация BIServer’а не очищает скрипты пула соединений при последовательном доступе к этим источникам.
Соответственно возникает малоинформативная ошибка [nQSError: 10058]
Ярлыки:
BIEE,
connection script,
XML
BIP: таймаут на длительные "ансверы"
Если вам приходится использовать BIEE поверх OLTP-источников, то, наверняка, часть ваших "ансверов" будет выполняться подолгу.
Допустим, ваши пользователи готовы с этим мириться.
Но тут вас ожидает небольшой подвох. При использовании BI Publisher’а в качестве средства форматирования «ансвера» для всех отчетов, источником которых является «ансвер» со временем выполнения больше 5-10 минут, будет генерироваться ошибка.
По прошествии означенных 5-10 минут пользователю будет выдаваться сообщение об ошибке вида «Request Cancelled», либо «Request timed out».
Первое сообщение «лечится» установкой параметров PresentationServer'а (файл instanceconfig.xml):
Второе сообщение:
В итоге файл instanceconfig.xml будет содержать следующие узлы:
Допустим, ваши пользователи готовы с этим мириться.
Но тут вас ожидает небольшой подвох. При использовании BI Publisher’а в качестве средства форматирования «ансвера» для всех отчетов, источником которых является «ансвер» со временем выполнения больше 5-10 минут, будет генерироваться ошибка.
По прошествии означенных 5-10 минут пользователю будет выдаваться сообщение об ошибке вида «Request Cancelled», либо «Request timed out».
Первое сообщение «лечится» установкой параметров PresentationServer'а (файл instanceconfig.xml):
<ConnectionExpireMinutes>60</ConnectionExpireMinutes>
<UnaccessedRunningTimeoutMinutes>60</UnaccessedRunningTimeoutMinutes>
Второе сообщение:
<ClientSessionExpireMinutes>60</ClientSessionExpireMinutes>
<SessionTimeoutSeconds>3600</SessionTimeoutSeconds>
<UIDefaultTimeoutMinutes>60</UIDefaultTimeoutMinutes>
В итоге файл instanceconfig.xml будет содержать следующие узлы:
<WebConfig>
<ServerInstance>
…
<UnaccessedRunningTimeoutMinutes>60</UnaccessedRunningTimeoutMinutes>
<ConnectionExpireMinutes>60</ConnectionExpireMinutes>
<ClientSessionExpireMinutes>60</ClientSessionExpireMinutes>
<SessionTimeoutSeconds>3600</SessionTimeoutSeconds>
<UIDefaultTimeoutMinutes>60</UIDefaultTimeoutMinutes>
…
</ServerInstance>
</WebConfig>
Ярлыки:
BI Publisher,
BIEE,
timeout
6 окт. 2009 г.
BIEE: вызов информационных панелей с инициализацией переменных презентаций
Приведенное решение является альтернативой GO-URL-метода (смотри, например, здесь).
С помощью GO-URL мы можем передать значения конкретных столбцов, определить условие фильтра по ним. Но задать значение переменной презентации при вызове дашборда извне нельзя.
С помощью GO-URL мы можем передать значения конкретных столбцов, определить условие фильтра по ним. Но задать значение переменной презентации при вызове дашборда извне нельзя.
2 окт. 2009 г.
BIP: блокирование управляющих элементов отчета до его завершения
Иногда приходится разрабатывать в BIP «тяжелые» отчеты, которые обрабатывают большие объемы данных, и время выполнения которых исчисляется десятками минут.
Что если такой отчет будет использоваться человеком нетерпеливым? Да еще и мало знакомым с «этой вашей системой»…
Что если такой отчет будет использоваться человеком нетерпеливым? Да еще и мало знакомым с «этой вашей системой»…
Ярлыки:
BI Publisher,
lock
29 сент. 2009 г.
BIP: Число прописью в RTF-шаблоне
Очень часто, в отчетных документах необходимо дублировать итоговую сумму прописью. Все хорошо, когда итоговая сумма известна ДО генерации отчета (например, посчитана в sql запросе и преобразована в пропись с помощью PL\SQL пакета). А что делать, когда сумма рассчитывается динамически, в самом RTF-шаблоне? Тут нам на помощь приходят XSL-функции и возможность использовать subtemplates(подшаблоны) в RTF-шаблоне.
Написав небольшую XSL-функцию для перевода числа в пропись:
Ярлыки:
BI Publisher,
FUNCTION,
RTF,
XML,
XSL
BIP: логгирование событий
Как включить логгирование событий BI Publisher? Об этом пишут все кому не лень – вот и я решил написать.
Ярлыки:
BI Publisher,
log,
xdodebug
15 сент. 2009 г.
BIEE: общий запрет на использование кеша Presentation Services
Не знаю как вы, а я устал постоянно отключать кеш Presentation Services для каждого "ансвера" в процессе разработки-тестирования.
Существует особый параметр для Presentation Services, запрещающий использование кеша на уровне системы.
Отредактируйте файл {OracleBIData}\web\config\instanceconfig.xml
Добавьте новый элемент <ForceRefresh> в узел <ServerInstance>
Перезапустите Presentation Server.
Список параметров доступен здесь
Существует особый параметр для Presentation Services, запрещающий использование кеша на уровне системы.
Отредактируйте файл {OracleBIData}\web\config\instanceconfig.xml
Добавьте новый элемент <ForceRefresh> в узел <ServerInstance>
<?xml version="1.0" encoding="utf-8"?>
<WebConfig>
<ServerInstance>
..........
<ForceRefresh>TRUE</ForceRefresh>
</ServerInstance>
</WebConfig>
Перезапустите Presentation Server.
Список параметров доступен здесь
BIEE: сохранение контекста при переходе между информационными панелями
Допустим, у вас есть несколько информационных панелей, использующих «ансверы» на одних и тех же предметных областях.
И вам не хочется при переходе на очередную информационную панель заново вводить значения подсказок панели.
И вам не хочется при переходе на очередную информационную панель заново вводить значения подсказок панели.
11 сент. 2009 г.
BIP: неявные параметры отчетов
Как узнать в запросе BI Publisher'а кто именно формирует отчет?
В какой стране он находится?
Какой язык предпочитает?
Всю эт информацию можно почерпнуть из неявных параметров для отчета.
xdo_user_name - имя пользователя, под которым запущен отчет;
xdo_user_roles - полномочия пользователя, запустившего отчет;
xdo_user_report_oracle_lang - язык отчета;
xdo_user_report_locale - локаль отчета;
xdo_user_ui_oracle_lang - язык интерфейса, под которым запущен отчет;
xdo_user_ui_locale - локаль интерфейса, под которой запущен отчет;
Их не требуется определять для каждого отчета.
Обращаться к ним можно так же, как к явным параметрам отчета - :xdo_user_name.
В какой стране он находится?
Какой язык предпочитает?
Всю эт информацию можно почерпнуть из неявных параметров для отчета.
xdo_user_name - имя пользователя, под которым запущен отчет;
xdo_user_roles - полномочия пользователя, запустившего отчет;
xdo_user_report_oracle_lang - язык отчета;
xdo_user_report_locale - локаль отчета;
xdo_user_ui_oracle_lang - язык интерфейса, под которым запущен отчет;
xdo_user_ui_locale - локаль интерфейса, под которой запущен отчет;
Их не требуется определять для каждого отчета.
Обращаться к ним можно так же, как к явным параметрам отчета - :xdo_user_name.
Ярлыки:
BI Publisher,
parameter
BIP: установка высоты фрейма отчета в binary-формате
Часто встречается следующая проблемка при интеграции BIP с внешними системами.
При вызове окна браузера, содержащего отчет BIP в не-HTML форматах (т.н. binary) и в режиме "только документ" (_xmode=4), внизу окна браузера видна пустая область примерно на 1/5 высоты. Ерунда, но раздражает.
Чтобы избавиться от этой области необходимо проделать следующее:
При вызове окна браузера, содержащего отчет BIP в не-HTML форматах (т.н. binary) и в режиме "только документ" (_xmode=4), внизу окна браузера видна пустая область примерно на 1/5 высоты. Ерунда, но раздражает.
Чтобы избавиться от этой области необходимо проделать следующее:
Ярлыки:
BI Publisher
BIP: Доступ к отчетам через URL
В общем виде адрес опубликованного в BIP отчета выглядит так:
где
server,port – имя и порт сервера, на котором запущен BIP;
xmlpserver – имя приложения (вы можете изменить его при ручном deploy приложения BIP);
Каталог отчета – папка, содержащая отчет;
Имя отчета – имя отчета (выводится 2 раза)
Для управления поведением публикуемого отчета можно (и нужно) использовать дополнительные параметры.
http://server:port/xmlpserver/<каталог отчета>/<имя отчета>/<имя отчета>.xdo
имя>имя>каталог>
где
server,port – имя и порт сервера, на котором запущен BIP;
xmlpserver – имя приложения (вы можете изменить его при ручном deploy приложения BIP);
Каталог отчета – папка, содержащая отчет;
Имя отчета – имя отчета (выводится 2 раза)
Для управления поведением публикуемого отчета можно (и нужно) использовать дополнительные параметры.
Ярлыки:
BI Publisher,
parameter,
URL
BIEE: Обновление XML,XLS-источников данных «на лету»
Во всех примерах, идущих в инсталляциях BIEE, репозиторий строится на XML-файлах.
Но нигде явно не настроена возможность обновления данных в этих источниках «на лету».
Чаще всего внешние файл – источники используются как связь с данными пользователей (выгрузка из 1С, какие-то Экселевские (куда без него) книги). И файлы эти имеют свойство изменяться.
Но, прописав связь с внешним файлом, вы заметите что любые изменения внесенные в данные файла не отобразятся в вашем «answer»-е. (Попробуйте на репозитории paint, например)
Как это исправить?
Но нигде явно не настроена возможность обновления данных в этих источниках «на лету».
Чаще всего внешние файл – источники используются как связь с данными пользователей (выгрузка из 1С, какие-то Экселевские (куда без него) книги). И файлы эти имеют свойство изменяться.
Но, прописав связь с внешним файлом, вы заметите что любые изменения внесенные в данные файла не отобразятся в вашем «answer»-е. (Попробуйте на репозитории paint, например)
Как это исправить?
Ярлыки:
BIEE,
data source,
onfly,
XLS,
XML
BIP: программный logout при доступе через URL
Что если вы используете BI Publisher в качестве инструмента отчетности в вашей информационной системе. И по каким-то причинам не используете стандартную поддержку SSO, а осуществляете разграничение полномочий в BIP c помощью передаваемых параметров URL'а с логином-паролем пользователя.
Может так случиться, что при наличии открытых окон браузера повторно переданные логин-пароль (уже отличные от предыдущих) не сработают.
Пример: вы зашли из внешней ИС в определенную папку с отчетами веб-интерфейса BIP под пользователем "user1", затем закрыли браузер, сделали logout из вашей исходной системы, НО где-то у вас "крутится" еще один браузер (картинки из "ВКонтакте" вы там смотрели...). И теперь при попытке зайти из вашей ИС под другим пользователем ("user2") вы получите сессию предыдущего пользователя.
Как этого избежать?
Может так случиться, что при наличии открытых окон браузера повторно переданные логин-пароль (уже отличные от предыдущих) не сработают.
Пример: вы зашли из внешней ИС в определенную папку с отчетами веб-интерфейса BIP под пользователем "user1", затем закрыли браузер, сделали logout из вашей исходной системы, НО где-то у вас "крутится" еще один браузер (картинки из "ВКонтакте" вы там смотрели...). И теперь при попытке зайти из вашей ИС под другим пользователем ("user2") вы получите сессию предыдущего пользователя.
Как этого избежать?
Ярлыки:
BI Publisher,
logout,
signout,
URL
BIEE: подсказка информационной панели на основе картинки
Не всегда стандартный функционал подсказок информационных панелей BIEE удовлетворяет нашим потребностям.
Что если вам нужно отфильтровать "answer"-ы по значениям столбцов (переменных презентации) после нажатия на определенные области картинки. Подобный функционал реализован в BIEE только в виде подсказок уровня "answer"-а.
Далее я расскажу, как подобное реализовать для дашбордов.
Подписаться на:
Сообщения (Atom)