Tim Tow
Happy 20th Anniversary to Applied OLAP!
Today, March 18, 2018, is the 20 year anniversary of our incorporation! I has been a long journey since that time; here are some of the highlights:
- 1998 - We were a one-man shop and wrote a reporting and budgeting application for a customer in New York. I spent about 150 nights that year on the road.
- 1999 - ActiveOLAP for Essbase was released and we earned the trust of two of our long-term customers. It was during the next couple of years that I traveled to the West Coast about 35 times in one year.
- 2003 - Portions of our web-service technology was acquired by Hyperion Solutions and we wrote the Hyperion Objects product based on that technology.
- 2007 - The Dodeca Spreadsheet Management System was released.
- 2014 - We hired our first resource to focus solely on sales. Prior to that, we marketed our software via 'word of mouth'.
- 2016 - The Dodeca Excel Add-In for Essbase was released and we acquired the DrillBridge product.
Thank you to all of our customers. We feel lucky to work with each and every one of you and we continue to learn from each of you. We pledge to continue working hard to make your companies successful.
Tim Tow
Founder and President
Applied OLAP, Inc
Categories: BI & Warehousing
Using MDX for Generated Members in Essbase Reports
There are times when Essbase users may need to see an ad-hoc collection of members aggregated together in Essbase, and that isn’t always an easy task. If it were an aggregation that is needed on a recurring basis, the Essbase administrator may add an alternate hierarchy to assist. Other times, users might just create a spreadsheet with the desired members in different rows or columns and use Excel formulas to add them together. In this blog post, I will cover a third option, the use of MDX to create dynamically-generated members, how to run them in Smart View, and how to make them much easier to use in Dodeca.
In order to illustrate how dynamically-generated members can be used, let’s consider an example using the Sample Basic database. Here is a simple quarterly income statement query that I will use as the basis for this blog post:
SELECT
{[Year].Children, Year} on COLUMNS,
Hierarchize(Descendants([Profit]), POST) ON ROWS
FROM
Sample.Basic
WHERE
([Market].[New York], [Product].[Colas], Actual)
The results from this simple query look like this:
This MDX is pretty straightforward, but what if you wanted to see how New York and Connecticut would look if they were combined? This is the question that a generated member can return for you.
Generated members in MDX are created using the WITH MEMBER clause. Moreover, the generated member can then be used anywhere a normal member can be used, even in a slicer dimension (or what we would call a ‘page field’ in the classic Essbase add-in or a point-of-view in Smart View). Here is the query modified to use the new generated member:
WITH MEMBER
[Market].[SelectedMarkets] AS 'SUM({[New York], [Connecticut]})'
SELECT
{[Year].Children, Year} on COLUMNS,
Hierarchize(Descendants([Profit]), POST) ON ROWS
FROM
Sample.Basic
WHERE
([Market].[SelectedMarkets], Colas, Actual)
The results from this query look like this:
So far, so good, but there are a couple of things to note. First, the member displayed in the POV is not a real member; that is to be expected. This leads to the second thing in that you cannot refresh the query as an ad-hoc analysis; the dynamically generated member name will be replaced with the dimension member name in its place.
To go even further, what if you want to have multiple generated members? In that case, the syntax is easy as you just continue with another MEMBER clause:
WITH MEMBER
[Market].[SelectedMarkets] AS 'SUM({[New York], [Connecticut]})'
MEMBER
[Product].[SelectedProducts] AS 'SUM({[Colas], [Grape]})'
SELECT
{[Year].Children, Year} on COLUMNS,
Hierarchize(Descendants([Profit]), POST) ON ROWS
FROM
Sample.Basic
WHERE
([Market].[SelectedMarkets], [Product].[SelectedProducts], Actual)
The results of this query look like this:
The syntax for creating and using generated members is not that difficult, but there are a couple of things that make it a bit more difficult than it should be for end users to use this approach.
First, any time end users start having to deal with scripts of any kind, the level of complexity goes up exponentially. As one of my mentors used to say, “The difference between zero lines of code and one line of code is much greater than the difference between one line of code and a hundred lines of code”. In other words, it is hard to get users to deal with code of any kind.
Second, once an end user has to ‘write a line of code’, or script in this case, then they assume the responsibility for it being correct. As there are differing levels of comfort and skill among users, the risk of error goes up.
Finally, when users use a script like the one used in this example, they have to type in the correct member names or, again, risk error. Here is the new MDX dialog in Smart View 11.1.2.5.720 showing where users type in the MDX including the member names.
To make it much easier for end users, Dodeca does a couple of things. First, Dodeca developers can configure reports to use MDX without the end user ever having to know that MDX is powering the report ‘under-the-covers’. Further, Dodeca has flexible Point-of-View selectors that allow the end user to simply pick which members they want to use in the query.
Dodeca report developers use tokens as a sort of substitution variables in the script. The tokens are replaced in the script at run-time by the members selected by end users. Here is the same script with tokens in place of the hard-coded values:
WITH MEMBER
[Market].[SelectedMarkets] AS 'SUM({[T.Market]})'
MEMBER
[Product].[SelectedProducts] AS 'SUM({[T.Product]})'
SELECT
{[Year].Children, Year} on COLUMNS,
Hierarchize(Descendants([Profit]), POST) ON ROWS
FROM
Sample.Basic
WHERE
([Market].[SelectedMarkets], [Product].[SelectedProducts], Actual)
The Dodeca Essbase Scripts editor has tools to help the report developer create and test MDX scripts. Here are the Test Tokens available in the editor that allow developers to simulate the values plugged in by the Point-of-View selectors:
And the script itself in the scripts editor which has built-in testing facilities:
Finally, here is a Dodeca view that utilizes the tokenized MDX query and allows users to easily select the members they want dynamically aggregated and the report is produced without the risk of error.
Let me know if you would like to learn more about Dodeca and how it could help your company.
Categories: BI & Warehousing
Windows 10 Update Killed Essbase On My Laptop!
Like many Essbase consultants and developers, I run Essbase server on my Windows 10 laptop. It was a lengthy ‘Creator’s Update’ Windows update and, once it was complete, Essbase was dead on my machine. So, what do I do? First, I didn’t panic; us pilots have a way of not panicking when things don’t go as planned. We have several people internally who had this happen to them over the past several months and we fixed it each time, so there was nothing to worry about.
The root cause was that my OPMN service, which runs Essbase, was gone. This happened on the other machines we have that experienced that in the past, so I went to talk with one of our resident infrastructure gurus, Jay Zuercher. I remembered there was a command that I could run to recreate the service; Jay had the command filed away somewhere and within a couple of minutes, he sent it to me:
SC CREATE "OracleProcessManager_epmsystem1" binPath="C:\oracle\middleware\epmsystem11r1\opmn\bin\opmn.exe -S -I c:\oracle\middleware\user_projects\epmsystem1”
I ran this command – as an administrator – and then went into services to set the service to start automatically and start the service running. That did not, however, result in Essbase coming back to life. Next, I looked at the Essbase logs and noted several issues having to do with security. Initially, I thought there may have been due to an issue with Shared Services, but then I remembered about the fairly common Essbase issue regarding a corrupted essbase.sec file. I don’t know if the corruption was related to the Windows Update, but the timing sure was suspect. I replaced the essbase.sec file with a backup copy and I was back in business.
Hopefully this doesn’t happen to you when you update Windows but, if it does, perhaps this blog post will make your recovery quick and painless.
Categories: BI & Warehousing
Possible solution for TLS 1.2 issues between Windows 10 and Oracle EPM Weblogic
We have recently seen some users of both Dodeca and Hyperion products where Windows 10 machines have issues connecting to the Weblogic servers shipped with Oracle EPM due to the absence of the TLS 1.2 protocol. The underlying issue is that Windows 10 is an evolution of technology whereas Oracle EPM Weblogic, and more specifically the Java version tested and shipped with it, are stuck in the stone age. Java 1.6 started its journey to "end of life" in late 2013 and, though it continues to be covered under Extended Support, the EPM team has not delivered an update for their server. Ironically, there is even a Java 1.6 version, Update 121, that now supports TLS 1.2; EPM is on Update 35.
So, what do you do? I would be very hesitant to upgrade the Java version delivered with the EPM System. After all, Oracle spent a lot of time working to certify on that version of Java. One of our Senior Support Engineers, Jay Zuercher, did find something that appears to work - it hasn't yet been widely tested but may be worth a try. Here are the steps he followed:
- Login to the Weblogic console.
- Navigate to Environment->Servers->AnalyticProviderServices0 (or to the server in which you are attempting to connect).
- Click on the SSL tab and expand the Advanced section at the bottom.
- Enable the “Use JSSE SSL” checkbox.
- Save changes.
- Navigate to the Server Start tab.
- Add the following string to the “Arguments” box:
- -Dweblogic.security.SSL.protocolVersion=TLS1
- Save changes.
- Activate all changes.
- Restart the applicable service.
Categories: BI & Warehousing
ACE Alumni
Today, I asked Oracle to move me from Oracle ACE Director status to Oracle ACE Alumni status. There are a number of reasons why I decided to change status. When I started answering questions on internet forums years ago, I did it to share what I had learned in order to help others. The same goes for this blog which I originally started so that I could give better and more complete answers to questions on the forums.
After the Hyperion acquisition by Oracle, I was contacted by Oracle who asked if I would be interested in becoming an "Oracle ACE". It was an honor. But over time, things have changed. As more people found out about the ACE program, more people wanted to become an ACE. If you have ever monitored the OTN Essbase and Smart View forums, they have become cluttered with copy and paste posts from people obviously trying to increase their points. As the ACE program grew, it also become harder for the OTN team to manage and now require a formal activity reporting - a time report if you will - to track contributions to the community. As I am already extremely pressed for time, I decided that tracking my contributions to the community - in exchange for a free pass to Open World, just didn't make sense.
All of that being said, just because I have moved to Oracle ACE Alumni status doesn't mean that I will stop contributing to the community. My company will continue to provide free downloads and support for the Next Generation (Essbase) Outline Extractor and the Outline Viewer along with free downloads of Drillbridge Community Edition. And maybe, just maybe, I will finally have time to write some new blog posts (maybe even some posts on some new Dodeca features inspired by our work with Oracle Analytics Cloud / Essbase Cloud!)
After the Hyperion acquisition by Oracle, I was contacted by Oracle who asked if I would be interested in becoming an "Oracle ACE". It was an honor. But over time, things have changed. As more people found out about the ACE program, more people wanted to become an ACE. If you have ever monitored the OTN Essbase and Smart View forums, they have become cluttered with copy and paste posts from people obviously trying to increase their points. As the ACE program grew, it also become harder for the OTN team to manage and now require a formal activity reporting - a time report if you will - to track contributions to the community. As I am already extremely pressed for time, I decided that tracking my contributions to the community - in exchange for a free pass to Open World, just didn't make sense.
All of that being said, just because I have moved to Oracle ACE Alumni status doesn't mean that I will stop contributing to the community. My company will continue to provide free downloads and support for the Next Generation (Essbase) Outline Extractor and the Outline Viewer along with free downloads of Drillbridge Community Edition. And maybe, just maybe, I will finally have time to write some new blog posts (maybe even some posts on some new Dodeca features inspired by our work with Oracle Analytics Cloud / Essbase Cloud!)
Categories: BI & Warehousing
Breaking News! Dodeca Spreadsheet Management System Certified on Oracle Analytics Cloud!
Now that the Oracle Analytics Cloud, or "OAC", has been released, we had to get serious about our work with one of the Oracle Analytics Cloud components, the Essbase Cloud Service, or "EssCS" for short. You would think that we should have been working hard on EssCS for quite some time, but we had been assured by Oracle product management that the Essbase Java API would be available in EssCS. Of course, Dodeca was built using the Essbase Java API and thus we expected that support for EssCS would be very easy.
We got access to a production version of the EssCS last week and started our work. As promised by product management, the Essbase Java API is available in EssCS and, believe it or not, we did not need to change a single line of source code in order to support the Essbase Cloud. We did, however, have to update our build processes to use Java 8 instead of the decrepit Java 6 used in Essbase 11.x.
As far as configuration inside Dodeca itself, the only change we made was that we configured the APSUrl in the Essbase Connection object to point to the Essbase Cloud APS instance. Note that the URL format has changed in the cloud. The Java API was accessible in Essbase 9.3.1 through Essbase 11.1.2.4 using the format:
http://<server>:<port>/aps/JAPI
In the cloud, this has changed to:
http://<server>:<port>/essbase/japi
The Essbase Connection configuration looks pretty much the same as the configuration for an on premise connection configuration:
Of course, the Dodeca views look identical when run against an on premise or a cloud server:
In summary, it was trivial to test Dodeca using EssCS. Every single Essbase functionality that we use in the product, from data grid operations to metadata operations and even report scripts, worked exactly the same as it does against an on premise Essbase cube. Based on our testing, we are certifying the Dodeca Spreadsheet Management System to work on the Oracle Analytics Cloud.
We have a number of innovations we plan to introduce in the near future aimed to improve the Essbase Cloud experience, so stay tuned. If you are planning to come to Kscope17 in San Antonio, plan to attend the Dodeca Symposium and you may just be the first to see of these cool new things!
We got access to a production version of the EssCS last week and started our work. As promised by product management, the Essbase Java API is available in EssCS and, believe it or not, we did not need to change a single line of source code in order to support the Essbase Cloud. We did, however, have to update our build processes to use Java 8 instead of the decrepit Java 6 used in Essbase 11.x.
As far as configuration inside Dodeca itself, the only change we made was that we configured the APSUrl in the Essbase Connection object to point to the Essbase Cloud APS instance. Note that the URL format has changed in the cloud. The Java API was accessible in Essbase 9.3.1 through Essbase 11.1.2.4 using the format:
http://<server>:<port>/aps/JAPI
In the cloud, this has changed to:
http://<server>:<port>/essbase/japi
The Essbase Connection configuration looks pretty much the same as the configuration for an on premise connection configuration:
Of course, the Dodeca views look identical when run against an on premise or a cloud server:
In summary, it was trivial to test Dodeca using EssCS. Every single Essbase functionality that we use in the product, from data grid operations to metadata operations and even report scripts, worked exactly the same as it does against an on premise Essbase cube. Based on our testing, we are certifying the Dodeca Spreadsheet Management System to work on the Oracle Analytics Cloud.
We have a number of innovations we plan to introduce in the near future aimed to improve the Essbase Cloud experience, so stay tuned. If you are planning to come to Kscope17 in San Antonio, plan to attend the Dodeca Symposium and you may just be the first to see of these cool new things!
Categories: BI & Warehousing
Kudos to the Dodeca Support Team!
Here at Applied OLAP, we have a great support team that we have tasked with doing their best to make sure our customers are happy with their Dodeca software. On most days, they are answering emails and firing up impromptu support webcasts to help our customers with any questions they have.
Today, we got some great feedback from a customer after a popup support webcast. Here is an email I received today from Edgardo Rodriguez at Wall Street law firm Sullivan and Cromwell (email used with permission):
So, here is a special call-out to our support team. Way to go!
Today, we got some great feedback from a customer after a popup support webcast. Here is an email I received today from Edgardo Rodriguez at Wall Street law firm Sullivan and Cromwell (email used with permission):
Hi Tim – just wanted to drop you a quick line on the tech support I received this morning. Kevin & Rodney were helping me with a headcount report. Have to tell you – they were great. They helped me leverage some of their code and walked me through the finer points of using it under our scripts – all under an hour! They also turned me on to using the SQL retrieve as a possible solution (which I will be using shortly).
I appreciate you support more than you know.
Just thought you should know..
Regards
Ed
So, here is a special call-out to our support team. Way to go!
Categories: BI & Warehousing
Essbase Cloud Service Webcast Available Online
Essbase Cloud Service is coming soon and, if you haven't had a chance to learn about it, here is how you can learn about it at your leisure. Oracle had a public webcast about two weeks ago and have made both the webcast and the slides available; you must have an Oracle login to see it. Here is the link to the EssCS webcast:
EssCS Webcast
And here is a link to the slides:
EssCS Webcast Slides
Essbase Cloud Service has some exciting new functionality that you should check out, even if you plan to keep your Essbase installations on-premise. Over time, I would expect that most, if not all, of the innovations you see will be released in the on-premise version of Essbase. If I were a betting man, I would guess the timing to be likely near the end of 2017 with the lrelease of "EPM 2017", which is the code name for the next major on-premise release,
Enjoy!
EssCS Webcast
And here is a link to the slides:
EssCS Webcast Slides
Essbase Cloud Service has some exciting new functionality that you should check out, even if you plan to keep your Essbase installations on-premise. Over time, I would expect that most, if not all, of the innovations you see will be released in the on-premise version of Essbase. If I were a betting man, I would guess the timing to be likely near the end of 2017 with the lrelease of "EPM 2017", which is the code name for the next major on-premise release,
Enjoy!
Categories: BI & Warehousing
Another Thanksgiving Email
Here is another email we got Wednesday from a Dodeca Excel Add-In for Essbase customer. This customer has a lot of VBA macros running some automation with Essbase and asked for some assistance. We told it was as easy as replacing they Essbase function declarations file with our Dodeca Add-In function declarations file, and then setting the variables that contain the location for the Dodeca-Essbase server. In other words, replace this file:
With this file:
With this file:
Easy, right? Here is the email:
I hadn't had a chance to test this massive file out with the latest version of the add-in yet, but was more than pleasantly surprised when I replaced the add-in code for the Dodeca wrapper and the only thing I had to do was change the connection to our new server and the file was live! It's truly drop and go! Thanks so much!!!!
Categories: BI & Warehousing
Happy Thanksgiving (Featuring an Email That I Am Thankful For)
I get tons of email every day and often have hundreds of emails that have to track on a daily basis which explains, in part, my absence from doing recent blog entries. Most of the emails I track are sales and support relating to Dodeca. After all, with Dodeca, the buck stops here, right? I also get some spam in the mix. Sometimes, there is an email that really makes my day. Here is one of those types I received this morning:
From: (masked)
Sent: Wednesday, November 23, 2016 8:48 AM
To: Applied OLAP Support
Subject: Happy Thanksgiving!
Although we are a smaller Essbase shop at 105 users, our users are strong advocates for Essbase and use it extensively. So, it is great timing to say how thankful I am to you and your teams for developing the Dodeca Essbase Add-In. At the end of the day, it’s the user experience that drives the support for Essbase and your product will excite our user base! [And, it requires little or no support from my team!]
Happy Thanksgiving to all!
Wow! This email really made my day! To our new customer that sent this email (and who graciously granted me permission to post her words), Happy Thanksgiving to you as well. We hope this is the first of many Thanksgivings that we work together!
Categories: BI & Warehousing
Thoughts/Info on Essbase/EssCS after Oracle Open World 2016
I was at Oracle Open World last week and have some notes to share on the upcoming EssCS (Essbase Cloud Service) product and on Essbase in general.
EssCS will be Infrastructure as a Service (IaaS) product and will be priced on the number of cores and memory. I believe there will be a metered and an unmetered pricing as well (metered meaning pay per cycle or some other usage measure). According to presentations at Open World, which did have safe harbor statements meaning "do not make decisions based on this info as it could change", there will be options for 1, 2, 4, or 16 physical cores ("OCPU's") and 7.5 to 15 Gb of RAM. In addition, it will be an updated version of Essbase that is not the current on-prem version. It will feature, among other things:
I do not remember hearing any dollar amount for EssCS at Open World. I expect availability in the next 3 to 6 months though it wouldn't surprise me if it were to slip further.
As far as on-prem Essbase updates, I would expect that the updates we see in EssCS will go on-prem as part of the EPM 2017 on-prem release which Oracle currently believes will be delivered late in 2017 (also subject to safe harbor, etc).
As far as how Oracle is selling Essbase, Essbase is now firmly in the BI organization and is being sold by the BI reps; EPM reps do not generally sell Essbase. To the Essbase team, EPM is important as they are an internal customer, but EPM is not their only customer. As such, I saw at least one presentation that promoted the idea of customers writing custom planning applications using Essbase. While some people I talked with thought that approach muddled the EPM message for customers, I see it as a situation where if they don't compete in the custom market, then someone else will. As someone who frequently is involved in complex applications where the EPM Planning product may not be a fit, I am thrilled to see that message from Oracle.
EssCS will be Infrastructure as a Service (IaaS) product and will be priced on the number of cores and memory. I believe there will be a metered and an unmetered pricing as well (metered meaning pay per cycle or some other usage measure). According to presentations at Open World, which did have safe harbor statements meaning "do not make decisions based on this info as it could change", there will be options for 1, 2, 4, or 16 physical cores ("OCPU's") and 7.5 to 15 Gb of RAM. In addition, it will be an updated version of Essbase that is not the current on-prem version. It will feature, among other things:
- The new Java Agent running in Weblogic that moves security from the essbase.sec file to a relational database.
- Simplified security
- ASO / BSO / Hybrid
- Sandboxing and scenario management - what if's without copying data with workflow for approval to merge into given scenarios
- Cloud-based UI
- Ability to specify/create an Essbase cube from Excel
- A cube template library ("app store" type of thing)
- A web-based outline editor (though most editing should be done in Excel)
- EssCLI (Essbase Command Line Interface) - a sort of EPMAutomate for Essbase
- The Essbase Java API and a new REST API (which is currently being engineered)
I do not remember hearing any dollar amount for EssCS at Open World. I expect availability in the next 3 to 6 months though it wouldn't surprise me if it were to slip further.
As far as on-prem Essbase updates, I would expect that the updates we see in EssCS will go on-prem as part of the EPM 2017 on-prem release which Oracle currently believes will be delivered late in 2017 (also subject to safe harbor, etc).
As far as how Oracle is selling Essbase, Essbase is now firmly in the BI organization and is being sold by the BI reps; EPM reps do not generally sell Essbase. To the Essbase team, EPM is important as they are an internal customer, but EPM is not their only customer. As such, I saw at least one presentation that promoted the idea of customers writing custom planning applications using Essbase. While some people I talked with thought that approach muddled the EPM message for customers, I see it as a situation where if they don't compete in the custom market, then someone else will. As someone who frequently is involved in complex applications where the EPM Planning product may not be a fit, I am thrilled to see that message from Oracle.
Categories: BI & Warehousing
Cool Essbase MDX Stuff – Dimension Properties Edition
I have always liked MDX as it exposes very powerful operations for creating member sets. It has this amazing ability to take a set of members, union it with another set of members, intersect it with yet another set of members, and then exclude members from yet another set. This is very powerful.
Recently, I was talking with a customer about some creative uses for MDX and they told me about some cool things they had done with MDX. Kudos to George Cooper and Esam Jaber at Gap for showing me some creative MDX. Though this is a really cool and new-to-me technique, after doing some online searches I found that the technique isn’t new to everyone. Both Gary Crisci and Harry Gates have blogged on it already at http://garycris.blogspot.com/2014/03/mdx-queries-to-get-parentchild-and.html and http://www.cubesavvy.com/cubesavvy-utilities-updated-mdx-capabilities, respectively.
This technique, which gives developers access to outline information that was not previously available, also seems to be lightning fast. I decided maybe I need to write on it as well and, of course, put my own spin on it by showing how we can use this in the Dodeca Spreadsheet Management System.
So, what is it? They are called dimension properties and can utilize the PROPERTY_EXPR function. This function provides the ability to query for, and return, members related to a given member. The ability to return related members, on the same row, is something that is unique to the Essbase query languages. The Grid API, or query-by-example and used to retrieve data from Essbase in the classic add-in, Smart View, and Dodeca, cannot do it out of the box. The Essbase Report Script language, which is frequently used for exporting data, cannot do it either. Regardless, we have customers who have asked to how have the parent member and/or the grandparent member on the same row as a member. In the remainder of this blog post, I will explain dimension properties, and more specifically, the PROPERTY_EXPR function.
For this post, I will use the Geography dimension of the ASOSamp.Sample database. The Geography dimension features members from different regions of the United States including details of the Region, the State, the City, and the Postal Code. Here is a screenshot of some members in the Geography dimension:
Geography dimension members
With this dimension, let’s suppose you would like to get outline information at the city level, or level 1 in Essbase-speak. In addition, let’s say you would like to have the state and the region as well. Finally, while we are at it, maybe you also want to know the generation number of the member. With dimension properties and the PROPERTY_EXPR function, you can get all of that information in one trip to the server. Here is the query:
Select {} on COLUMNS,
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
DIMENSION PROPERTIES
GEN_NUMBER,
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2"),
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(3)),"Gen3")
ON ROWS
FROM ASOSamp.Sample
Let’s break down the query to examine the components. First, the Column axis specification is simple:
Select {} on COLUMNS,
The Column axis specification contains an empty set, but why do you need to even specify a set at all? The Essbase MDX specification states that a query cannot skip axes based on a set order. It seems much more natural for me to get data back on the second axis, or the Row axis, and as the Column axis is the first specified axis, a query cannot skip the Column axis and specify a Row axis. As we really aren’t looking for any data to be returned in this query, then we can just use an empty set.
Next, let’s look at the Row axis specification:
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
Let’s split this into sections starting from the inside out. The Descendants function returns, naturally, all of the descendants of a given member down to, and including, level 1 members in the outline. For this database, this query will return the Geography dimension down to the City level, but will not return the bottom, or zip code, level.
The member set returned by the Descendants function is then sorted by the Hierarchize function.
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
The POST argument specifies that child members are sorted before their parent as they are in the spreadsheet add-ins.
Next, the DIMENSION PROPERTIES modifier for the Row axis specification provides the ability to return additional outline information related to each member returned in the set. The DIMENSION PROPERTIES specify that the generation number, the related generation 2 and generation 3 members are returned for each member in the set.
DIMENSION PROPERTIES
GEN_NUMBER,
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2"),
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(3)),"Gen3")
The GEN_NUMBER argument is self-explanatory, so let’s look at the PROPERTY_EXPR function to see how it works. Consider this portion of the statement:
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2")
The first argument is the dimension name, so that is easy enough.
The second argument, called the property_name argument, has a number of valid values as documented by Oracle in the documentation. Valid values are MEMBER_NAME, MEMBER_ALIAS, LEVEL_NUMBER, GEN_NUMBER, IS_EXPENSE, COMMENTS, RELATIONAL_DESCENDANTS, MEMBER_UNIQUE_NAME), an attribute dimension name, an alias-table name, or a UDA. At the time of this writing, the current docs are located at http://docs.oracle.com/cd/E26232_01/doc.11122/esb_tech_ref/frameset.htm?mdx_property_expressions.html.
The third argument is called member_value_expression and this is where the magic happens. In this argument, you can use a number of functions that return exactly one member that is related to the current member. In my example above, the Ancestor function is being used to return, for each member in the set as specified by the CurrentAxisMember function, the ancestor of that member at a given generation. Among other functions are functions that allow you to get the parent, first child, next sibling, or previous sibling of the current member.
The fourth and final argument is used to give a title to the column containing the extended information.
So, now that we know a bit about this syntax, what does it look like in EAS?
MDX dimension properties in EASIn their blogs, both Gary and Harry talk about ways to actually consume this information. Harry wrote a special interface to display dimension properties returned by MDX. Gary talked about the idea of using an Excel macro to parse the output. I had my own ideas on how to use dimension properties in Dodeca. I setup a simple Dodeca report and used a only 3 lines of our automation language, workbook scripting, to build the view. Here is screenshot of my simple Dodeca view.
Dynamic MDX View in DodecaWhile running this view in Dodeca, the user can filter based on Geography, Product, and Stores dimensions and the report is highly dynamic. The automation in Dodeca performs these tasks:
So, how could you use dimension properties?
Recently, I was talking with a customer about some creative uses for MDX and they told me about some cool things they had done with MDX. Kudos to George Cooper and Esam Jaber at Gap for showing me some creative MDX. Though this is a really cool and new-to-me technique, after doing some online searches I found that the technique isn’t new to everyone. Both Gary Crisci and Harry Gates have blogged on it already at http://garycris.blogspot.com/2014/03/mdx-queries-to-get-parentchild-and.html and http://www.cubesavvy.com/cubesavvy-utilities-updated-mdx-capabilities, respectively.
This technique, which gives developers access to outline information that was not previously available, also seems to be lightning fast. I decided maybe I need to write on it as well and, of course, put my own spin on it by showing how we can use this in the Dodeca Spreadsheet Management System.
So, what is it? They are called dimension properties and can utilize the PROPERTY_EXPR function. This function provides the ability to query for, and return, members related to a given member. The ability to return related members, on the same row, is something that is unique to the Essbase query languages. The Grid API, or query-by-example and used to retrieve data from Essbase in the classic add-in, Smart View, and Dodeca, cannot do it out of the box. The Essbase Report Script language, which is frequently used for exporting data, cannot do it either. Regardless, we have customers who have asked to how have the parent member and/or the grandparent member on the same row as a member. In the remainder of this blog post, I will explain dimension properties, and more specifically, the PROPERTY_EXPR function.
For this post, I will use the Geography dimension of the ASOSamp.Sample database. The Geography dimension features members from different regions of the United States including details of the Region, the State, the City, and the Postal Code. Here is a screenshot of some members in the Geography dimension:
Geography dimension members
With this dimension, let’s suppose you would like to get outline information at the city level, or level 1 in Essbase-speak. In addition, let’s say you would like to have the state and the region as well. Finally, while we are at it, maybe you also want to know the generation number of the member. With dimension properties and the PROPERTY_EXPR function, you can get all of that information in one trip to the server. Here is the query:
Select {} on COLUMNS,
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
DIMENSION PROPERTIES
GEN_NUMBER,
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2"),
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(3)),"Gen3")
ON ROWS
FROM ASOSamp.Sample
Let’s break down the query to examine the components. First, the Column axis specification is simple:
Select {} on COLUMNS,
The Column axis specification contains an empty set, but why do you need to even specify a set at all? The Essbase MDX specification states that a query cannot skip axes based on a set order. It seems much more natural for me to get data back on the second axis, or the Row axis, and as the Column axis is the first specified axis, a query cannot skip the Column axis and specify a Row axis. As we really aren’t looking for any data to be returned in this query, then we can just use an empty set.
Next, let’s look at the Row axis specification:
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
Let’s split this into sections starting from the inside out. The Descendants function returns, naturally, all of the descendants of a given member down to, and including, level 1 members in the outline. For this database, this query will return the Geography dimension down to the City level, but will not return the bottom, or zip code, level.
The member set returned by the Descendants function is then sorted by the Hierarchize function.
Hierarchize(Descendants(Geography, Geography.Levels(1), SELF_AND_BEFORE), POST)
The POST argument specifies that child members are sorted before their parent as they are in the spreadsheet add-ins.
Next, the DIMENSION PROPERTIES modifier for the Row axis specification provides the ability to return additional outline information related to each member returned in the set. The DIMENSION PROPERTIES specify that the generation number, the related generation 2 and generation 3 members are returned for each member in the set.
DIMENSION PROPERTIES
GEN_NUMBER,
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2"),
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(3)),"Gen3")
The GEN_NUMBER argument is self-explanatory, so let’s look at the PROPERTY_EXPR function to see how it works. Consider this portion of the statement:
PROPERTY_EXPR(Geography, MEMBER_NAME, Ancestor(CurrentAxisMember(), Geography.Generations(2)),"Gen2")
The first argument is the dimension name, so that is easy enough.
The second argument, called the property_name argument, has a number of valid values as documented by Oracle in the documentation. Valid values are MEMBER_NAME, MEMBER_ALIAS, LEVEL_NUMBER, GEN_NUMBER, IS_EXPENSE, COMMENTS, RELATIONAL_DESCENDANTS, MEMBER_UNIQUE_NAME), an attribute dimension name, an alias-table name, or a UDA. At the time of this writing, the current docs are located at http://docs.oracle.com/cd/E26232_01/doc.11122/esb_tech_ref/frameset.htm?mdx_property_expressions.html.
The third argument is called member_value_expression and this is where the magic happens. In this argument, you can use a number of functions that return exactly one member that is related to the current member. In my example above, the Ancestor function is being used to return, for each member in the set as specified by the CurrentAxisMember function, the ancestor of that member at a given generation. Among other functions are functions that allow you to get the parent, first child, next sibling, or previous sibling of the current member.
The fourth and final argument is used to give a title to the column containing the extended information.
So, now that we know a bit about this syntax, what does it look like in EAS?
MDX dimension properties in EASIn their blogs, both Gary and Harry talk about ways to actually consume this information. Harry wrote a special interface to display dimension properties returned by MDX. Gary talked about the idea of using an Excel macro to parse the output. I had my own ideas on how to use dimension properties in Dodeca. I setup a simple Dodeca report and used a only 3 lines of our automation language, workbook scripting, to build the view. Here is screenshot of my simple Dodeca view.
Dynamic MDX View in DodecaWhile running this view in Dodeca, the user can filter based on Geography, Product, and Stores dimensions and the report is highly dynamic. The automation in Dodeca performs these tasks:
- Returns members and properties as the descendants of a user-selected Geography member
- Retrieves and places the dimension properties and the members on the worksheet
- Places the selected Product and Stores dimension members in the proper location
- Retrieves Essbase data into the worksheet
- Creates Excel grouping based on the generation number
So, how could you use dimension properties?
Categories: BI & Warehousing
ODTUG Leadership Program / ODTUG Board Elections
As many of you know, I have spent many years helping the Hyperion community in many ways. I have wrote this blog for quite some time, have taken on the OlapUnderground Utilities and provided free support through my company, In other words, I have worked hard to give back to the community and, in return, have had many kind words from people we have helped.
As a result of this spirit of giving back, I was lucky enough to be elected to the ODTUG Board of Directors which brings me to the real point of this blog post. There is an upcoming ODTUG Board Election coming up and, due to term limits, my time on the board is coming to a close. The same is true of my good friend Cameron Lackpour. With two board seats open, could *you* be the next person to step up?
Here are my thoughts on what it takes to be a board member. Joining the ODTUG Board isn't just something you decide to do and it isn't an achievement that is 'a feather in someone's hat'. It is a commitment to helping others in the community for two years. But it is more than that. To be a successful ODTUG Board member, the commitment you have should be a continuation of the long-term commitment you have made to helping others. So, if you are interested in serving on the ODTUG Board at some time in the future, the thing you should do is #GetInvolved. If you are not already involved, the easiest way to get involved is to volunteer on the ODTUG Volunteer page.
If you are ready to step up from that point, for a number of years, ODTUG has maintained a Leadership Program to help train the next generation of users. The application process for this year's Leadership Program is open for another week. For more information, or to submit an application for the Leadership Program, you can get more information on the ODTUG Leadership Program page.
As a result of this spirit of giving back, I was lucky enough to be elected to the ODTUG Board of Directors which brings me to the real point of this blog post. There is an upcoming ODTUG Board Election coming up and, due to term limits, my time on the board is coming to a close. The same is true of my good friend Cameron Lackpour. With two board seats open, could *you* be the next person to step up?
Here are my thoughts on what it takes to be a board member. Joining the ODTUG Board isn't just something you decide to do and it isn't an achievement that is 'a feather in someone's hat'. It is a commitment to helping others in the community for two years. But it is more than that. To be a successful ODTUG Board member, the commitment you have should be a continuation of the long-term commitment you have made to helping others. So, if you are interested in serving on the ODTUG Board at some time in the future, the thing you should do is #GetInvolved. If you are not already involved, the easiest way to get involved is to volunteer on the ODTUG Volunteer page.
If you are ready to step up from that point, for a number of years, ODTUG has maintained a Leadership Program to help train the next generation of users. The application process for this year's Leadership Program is open for another week. For more information, or to submit an application for the Leadership Program, you can get more information on the ODTUG Leadership Program page.
Categories: BI & Warehousing
Announcing the Dodeca Spreadsheet Management System, Version 7 and the Dodeca Excel Add-In for Essbase
After 18 months of hard work, Applied OLAP is proud to announce the general availability of the Dodeca Spreadsheet Management System, version 7, and the all-new Dodeca Excel Add-In for Essbase.
The Dodeca Spreadsheet Management System provides customers the ability to automate spreadsheet functionality, reducing the risk of spreadsheet errors while increasing productivity. It combines unprecedented ease-of-use for business users using spreadsheets for planning, budgeting, forecasting, reporting and analysis tasks. It also provides a robust, programmable development environment enabling companies to create spreadsheet applications tailored to their specific needs.
The new Dodeca Excel Add-In for Essbase was created as a drop-in replacement for the classic Essbase add-in and is the world’s only Excel add-in focused exclusively on Essbase. The new add-in supports the most common actions used by Essbase traditionalists, supports the corresponding VBA functions, and includes a built-in Excel ribbon. Early adopters have also been impressed by the speed of retrieving data, commenting they found the Dodeca Excel Add-In as fast as, or even faster, than the classic Excel Add-In for Essbase. It is supported for Excel 2010, 2013, and 2016 and for Essbase 9.3.1 and higher.
Dodeca 7 includes new features and functionality for security, selectors, logging, and enhanced workbook scripting.
The enhanced security features add the ability to more easily manage users, roles, and permissions to access a Dodeca application. The new security features include:
The selector enhancements include improvements to both view selectors and member selectors. The improvements include:
The new workbook script functionality includes:
256.885.4371.
The Dodeca Spreadsheet Management System provides customers the ability to automate spreadsheet functionality, reducing the risk of spreadsheet errors while increasing productivity. It combines unprecedented ease-of-use for business users using spreadsheets for planning, budgeting, forecasting, reporting and analysis tasks. It also provides a robust, programmable development environment enabling companies to create spreadsheet applications tailored to their specific needs.
The new Dodeca Excel Add-In for Essbase was created as a drop-in replacement for the classic Essbase add-in and is the world’s only Excel add-in focused exclusively on Essbase. The new add-in supports the most common actions used by Essbase traditionalists, supports the corresponding VBA functions, and includes a built-in Excel ribbon. Early adopters have also been impressed by the speed of retrieving data, commenting they found the Dodeca Excel Add-In as fast as, or even faster, than the classic Excel Add-In for Essbase. It is supported for Excel 2010, 2013, and 2016 and for Essbase 9.3.1 and higher.
Dodeca 7 includes new features and functionality for security, selectors, logging, and enhanced workbook scripting.
The enhanced security features add the ability to more easily manage users, roles, and permissions to access a Dodeca application. The new security features include:
- User Management – You can now track, monitor, and control user access to a Dodeca application and more easily monitor your Dodeca user base. This feature enables customers to control individual user access to a specific application, enable users for admin access, and manage user mapping to roles while also tracking metrics such as the first, last, and count of user logins. This feature also logs metrics on the users system to enable Dodeca administrators to more easily support their users.
Here is an example of the metrics stored for each user record.
- User Roles – In addition to provisioning roles via Essbase, Microsoft Active Directory, or LDAP groups using Dodeca authentication services, you can now create your own groups directly in Dodeca and map them to users. In addition, these new roles can be configured to be additive to the roles provided by other authentication services.
- Application Session Timeout – You can now prevent users from keeping a Dodeca session open indefinitely by specifying an inactivity timeout or by specifying a designated shutdown time.
The new logging features provide the ability for customers to both easily track what their users are running in the system and assist our support team if and when support is needed. The new logging features include:
- View Usage Logging – View usage is now automatically logged in the server. The logs include not only identifying information for the view and the user, but also include performance information, error information, and tokens used in the view generation.
- Client-side Request and Response XML Logging – The XML traffic traveling between the client and the server may now be logged to a directory on the client machine. This logging expands on the Server-side Request and Response XML Logging to make it easier to gather the XML traffic for a single user. In turn, the XML captured can be used by our support team to easily replicate transactions for our developers if and when necessary.
The selector enhancements include improvements to both view selectors and member selectors. The improvements include:
- View Selector Relational Hierarchy Generation – You may now populate the entire View Hierarchy, or alternatively, populate one or more branches, based on the results of a relational query.
- View Selector Hierarchy Item Access Filters – Previously, you could control the View Hierarchies available to a given user. This new filter provides the ability to control which view hierarchy items are presented in the view selector based on the current user’s roles.
- Relational Treeview Point-of-View Selector List– You may now configure a hierarchy of point-of-view items based on the results of a relational query.
- Enhanced Essbase Treeview Point-of-View Selector List Expansion and Selection Filtering – You can now filter Essbase member content and selectable status based on one or more specified filters including generation number, level number, member name, alias, or shared status.
- Enhanced SQLPassthroughDataSet Query Editing – You can now define token values to use for testing tokenized SQL queries in the Test Data Set utility.
- Improved Token Editor – You can now view and edit tokens and their values in an improved grid layout.
The new workbook script functionality includes:
- New Events
- BeforeBuildExecute - Allows a workbook script to cancel the build before the view is covered.
- BeforeRefreshExecute - Allows a workbook script to cancel the refresh before the view is covered.
- Shown - Raised when the view is initially shown. The event is raised before the framework applies the view’s AutoBuildOnOpen property, which allows a workbook script to set the property dynamically.
- New Methods
- ExportToExcel – Provides the ability to export view and point-of-view information in an exported Excel file. This information is used to regenerate the view upon Excel file import which enables off-line data entry in Excel with subsequent database updates in Dodeca.
- SetSelectorConfiguration - Provides the ability to add or remove a point-of-view selector to/from a view dynamically.
- Enhanced Methods
- CallWebService – Added a new RESTRequest overload, which allows web service calls to made to RESTful web services.
- SendEmail - Added a new ServletSMTP overload, which sends email from the Dodeca server rather than from the client. This is useful in circumstances in which SMTP mail must come from an approved IP address.
- SetEntry – Added a new Added FormulaArray overload which allows Excel array formulas to be entered programmatically.
- SetFill - Added a new Clear overload, which clears the fill color and pattern from the specified range.
- New Functions
- ColumnWidth - Returns the column width based on the active cell or a given cell.
- RowHeight - Returns the row height based on the active cell or a given cell.
- DataPointHasCellNote - Returns a boolean indicating if the active or specified data cell has Essbase LRO cell notes associated with it.
- IsInCharacterRange - Returns a boolean indicating whether the specified string is limited to the specified character range. This function can be used to detect multi-byte characters in a string.
- Enhanced Functions
- SheetCount - Added an optional IncludeHiddenSheets argument, which controls whether the returned count includes both visible and hidden sheets or only visible sheets.
256.885.4371.
Categories: BI & Warehousing
Next Generation Outline Extractor 2.0.5.1073 released
In the last week or so, we placed an updated version of the Next Generation Outline Extractor on our website. This version provides support for some updated Essbase versions, including 11.1.2.4.002, 11.1.2.4.003, and 11.1.2.4.005. More importantly, it addresses a bug where alias names were improperly associated with parent members when using the MaxL extraction source.. This bug was reported to us by a number of users and we are glad we were able to address it. Here is a list of the issues that were addressed:
2015.11.23 - Issue 1401 - Resolved an issue where only one alias table is exported when using MaxL as the extract source.
2015.11.23 - Issue 1402 - Resolved an issue where extracts using MaxL input and having members specified with Unicode may print incorrect characters in the output.
2015.11.23 - Issue 1403 - Resolved an issue where aliases and udas may have been improperly placed on parent members.
Please contact our support team if you have any issues.
Categories: BI & Warehousing
Fundamentals of SQL Writeback in Dodeca
One of the features of Dodeca is read-write functionality to SQL databases. We often get questions as to how to write data back to a relational database, so I thought I would post a quick blog entry for our customers to reference.
This example will use a simple table structure in SQL Server though the concepts are the same when using Oracle, DB2, and most other relational databases. The example will use a simple Dodeca connection to a JDBC database. Here is the Dodeca SQL Connection object used for the connection.
The table I will use for this example was created with the following CREATE TABLE statement.
CREATE TABLE [dbo].[Test](
[TestID] [int] IDENTITY(1,1) NOT NULL,
[TestCode] [nvarchar](50) NULL,
[TestName] [nvarchar](50) NULL,
CONSTRAINT [PK_Test] PRIMARY KEY CLUSTERED
([TestID] ASC)
)
Next, modify the DataSetRanges property of the Dodeca View object and, to enable insert operations, set the AllowAddRow property to True. Note that if you added update and/or delete SQL to your SQL Passthrough Dataset object, be sure to enable those operations on the worksheet via the AllowDeleteRow and AllowModifyRow properties.
Once this step is complete, you can run the Dodeca View, add a row, and press the Save button to save the record to the relational database.
The insert, update, and delete functionalities using plain SQL statements is limited to operations on a single table. If you need to do updates on multiple tables, you must use stored procedures to accomplish the functionality. You can call a stored procedure in Dodeca using syntax similar to the following example:
{call sp_InsertTest(@TestCode, @TestName)}
Dodeca customers can contact support for further information at support@appliedolap.com.
This example will use a simple table structure in SQL Server though the concepts are the same when using Oracle, DB2, and most other relational databases. The example will use a simple Dodeca connection to a JDBC database. Here is the Dodeca SQL Connection object used for the connection.
The table I will use for this example was created with the following CREATE TABLE statement.
CREATE TABLE [dbo].[Test](
[TestID] [int] IDENTITY(1,1) NOT NULL,
[TestCode] [nvarchar](50) NULL,
[TestName] [nvarchar](50) NULL,
CONSTRAINT [PK_Test] PRIMARY KEY CLUSTERED
([TestID] ASC)
)
First, I used the Dodeca SQL Excel View Wizard to create a simple view in Dodeca to retrieve the data into a spreadsheet. The view, before setting up writeback capabilities, looks like this.
To make this view writeable, follow these steps.
- Add the appropriate SQL insert, update, or delete statements to the Dodeca SQL Passthrough Dataset object. The values to be replaced in the SQL statement must be specified using the notation @ColumnName where ColumnName is the column name, or column alias, of the column containing the data.
- Add the column names of the primary key for the table to the PrimaryKey property of the SQL Passthrough DataSet object.
- Depending on the database used, define the column names and their respective JDBC datatypes in the Columns property of the SQL Passthrough Dataset. This mapping is optional for SQL Server because Dodeca can obtain the required information from the Microsoft JDBC driver, however, the Oracle and DB2 JDBC drivers do not provide this information and it must be entered by the developer.
For insert, update, and delete operations, Dodeca parses the SQL statement to read the parameters that use the @ indicator and creates a JDBC prepared statement to execute the statements. The prepared statement format is very efficient as it compiles the SQL statement once and then executes it multiple times. Each inserted row is also passed to the server during the transaction. The values from each row are then used in conjunction with the prepared statement to perform the operation.
Here is the completed Query definition.
Here is the completed Query definition.
Next, modify the DataSetRanges property of the Dodeca View object and, to enable insert operations, set the AllowAddRow property to True. Note that if you added update and/or delete SQL to your SQL Passthrough Dataset object, be sure to enable those operations on the worksheet via the AllowDeleteRow and AllowModifyRow properties.
Once this step is complete, you can run the Dodeca View, add a row, and press the Save button to save the record to the relational database.
The insert, update, and delete functionalities using plain SQL statements is limited to operations on a single table. If you need to do updates on multiple tables, you must use stored procedures to accomplish the functionality. You can call a stored procedure in Dodeca using syntax similar to the following example:
{call sp_InsertTest(@TestCode, @TestName)}
Dodeca customers can contact support for further information at support@appliedolap.com.
Categories: BI & Warehousing
Next Generation Outline Extractor 2.0.4.887 Released
We recently released an updated version of the Next Generation Outline Extractor. This new version, 2.0.4.887, addresses three issues:
- Fixed an issue where the username and password passed via the command line were improperly logged
- Fixed an issue reading MaxL XML data sources when the alias or UDA contained xml encoded characters such as the ampersand (&) character.
- Updated labels on the Input Source tab of the user interface to clarify their purpose.
Due to the architecture of the Oracle Essbase APIs, it is generally much faster to use the MaxL Outline XML extracts when processing an Essbase Outline extract. The Next Generation Outline Extractor still uses the Essbase Java API during this extract, but it is able to minimize the number of calls. The second option shown above, Extract and Process MaxL Outline XML, will automatically extract the Outline XML from the cube during the processing. The third option shown, Use Previously Extracted MaxL Outline XML, uses (obviously) an Outline XML file that has already been extracted.
Thank you to everyone who reported issues or made suggestions as you help make this utility better!
Categories: BI & Warehousing
New OlapUnderground Utility - The Essbase Outline Viewer
Have you ever wanted your users to see an Essbase database outline structure, but had trouble giving them access to Essbase Administrative Services ("EAS") for fear that they may have access to change things they shouldn't change? Maybe you didn't want to give them EAS and have to deal with the version of Java installed on their machine? We have the solution to your problems. After a bit of fits and starts, we have finally released the OlapUnderground Essbase Outline Viewer!
The OlapUnderground Essbase Outline Viewer is a read-only user interface built specifically to view the contents of an Essbase outline. It is built in Microsoft .NET technology and should run on any Windows-based computer without any special downloads. It also uses the MaxL outline xml format and, as your Hyperion administrators can create and distribute the outline xml file, end users do not need an Essbase login to view the outline.
Here is a screenshot of the Outline Viewer:
Click image to see it full-sizeYou can download the Essbase Outline Viewer from our website at http://www.appliedolap.com/resources/downloads/essbase-outline-viewer. Let us know what you think!
The OlapUnderground Essbase Outline Viewer is a read-only user interface built specifically to view the contents of an Essbase outline. It is built in Microsoft .NET technology and should run on any Windows-based computer without any special downloads. It also uses the MaxL outline xml format and, as your Hyperion administrators can create and distribute the outline xml file, end users do not need an Essbase login to view the outline.
Here is a screenshot of the Outline Viewer:
Click image to see it full-sizeYou can download the Essbase Outline Viewer from our website at http://www.appliedolap.com/resources/downloads/essbase-outline-viewer. Let us know what you think!
Categories: BI & Warehousing
Next Generation Outline Extractor - New Version Available
Today we released a new version of the Next Generation Outline Extractor, version 2.0.3.769. Here are the release notes from this new version:
Version 2.0.3.769 supports the following Essbase versions:
9.3.1
9.3.1.1
9.3.1.2
9.3.3
11.1.1
11.1.1.1
11.1.1.2
11.1.1.3
11.1.1.4
11.1.2
11.1.2.1
11.1.2.1.102
11.1.2.1.103
11.1.2.1.104
11.1.2.1.105
11.1.2.1.106
11.1.2.2
11.1.2.2.102
11.1.2.2.103
11.1.2.2.104
11.1.2.3
11.1.2.3.001
11.1.2.3.002
11.1.2.3.003
11.1.2.3.500
11.1.2.3.501
11.1.2.3.502
11.1.2.3.505
11.1.2.4
Issues resolved in version 2.0.3.769:
2015.02.15 - Issue 1355 - All Writers - Add functionality to replace all line feeds, carriage returns, tabs, and extraneous spaces in formulas
2015.02.13 - Issue 1354 - RelationalWriter - Changed the default database name from dodeca to extractor
2015.02.13 - Issue 1353 - RelationalWriter - Added CONSOLIDATION_TYPE_SYMBOL, SHARE_FLAG_SYMBOL, TIME_BALANCE, TIME_BALANCE_SYMBOL, TIME_BALANCE_SKIP, TIME_BALANCE_SKIP_SYMBOL, EXPENSE_FLAG, EXPENSE_FLAG_SYMBOL, TWO_PASS_FLAG, and TWO_PASS_FLAG_SYMBOL columns to the CACHED_OUTLINE_MEMBERS table
2015.02.13 - Issue 1352 - RelationalWriter - Added Server, Application, and Cube columns to the CACHED_OUTLINE_VERSIONS table
2015.02.13 - Issue 1351 - Fixed issue with LoadFileWriter where UDA column headers were incorrectly written in the form UDAS0,DimName instead of UDA0,DimName
In addition, a number of fixes, etc, were put into 2.0.2 and earlier releases and those releases went unannounced. Those updates included the following items:
Version 2.0.3.769 supports the following Essbase versions:
9.3.1
9.3.1.1
9.3.1.2
9.3.3
11.1.1
11.1.1.1
11.1.1.2
11.1.1.3
11.1.1.4
11.1.2
11.1.2.1
11.1.2.1.102
11.1.2.1.103
11.1.2.1.104
11.1.2.1.105
11.1.2.1.106
11.1.2.2
11.1.2.2.102
11.1.2.2.103
11.1.2.2.104
11.1.2.3
11.1.2.3.001
11.1.2.3.002
11.1.2.3.003
11.1.2.3.500
11.1.2.3.501
11.1.2.3.502
11.1.2.3.505
11.1.2.4
Issues resolved in version 2.0.3.769:
2015.02.15 - Issue 1355 - All Writers - Add functionality to replace all line feeds, carriage returns, tabs, and extraneous spaces in formulas
2015.02.13 - Issue 1354 - RelationalWriter - Changed the default database name from dodeca to extractor
2015.02.13 - Issue 1353 - RelationalWriter - Added CONSOLIDATION_TYPE_SYMBOL, SHARE_FLAG_SYMBOL, TIME_BALANCE, TIME_BALANCE_SYMBOL, TIME_BALANCE_SKIP, TIME_BALANCE_SKIP_SYMBOL, EXPENSE_FLAG, EXPENSE_FLAG_SYMBOL, TWO_PASS_FLAG, and TWO_PASS_FLAG_SYMBOL columns to the CACHED_OUTLINE_MEMBERS table
2015.02.13 - Issue 1352 - RelationalWriter - Added Server, Application, and Cube columns to the CACHED_OUTLINE_VERSIONS table
2015.02.13 - Issue 1351 - Fixed issue with LoadFileWriter where UDA column headers were incorrectly written in the form UDAS0,DimName instead of UDA0,DimName
In addition, a number of fixes, etc, were put into 2.0.2 and earlier releases and those releases went unannounced. Those updates included the following items:
- There is no longer a default .properties file for the Extractor. This will force a user to specify a .properties file. (2.0.2.601)
- Removed the "/" character as a switch for command line arguments as it causes problems in Linux. (2.0.2.605)
- Fixed issue when combining MaxL input with relational output where a "not supported" error message would appear due to certain properties were not being read correctly from the XML file (2.0.2.601)
- Command line operations resulted in an error due to an improper attempt to interact with the GUI progress bar. (2.0.2.601)
- Shared members attributes where not be properly written resulting in a delimiter/column count mismatch. (2.0.2.625)
- Added encoding options where a user can choose between UTF-8 and ANSI encodings. The Extractor will attempt to detect encoding from selected outline and, if the detected outline encoding is different from the user selected outline encoding, a warning message appears.
Categories: BI & Warehousing
Ephemeral Port Issue with Essbase Has Been Fixed!
The issue that has plagued a number of Essbase customers over the years related to running out of available ports has finally been fixed!
This issue, which often manifested itself with errors in the Essbase error 10420xx range, was caused by how the Essbase Java API communicated with the server. In essence, whenever a piece of information was needed, the Essbase Java API grabbed a port from the pool of available ports, did its business, and then released the port back to the pool. That doesn’t sound bad, but the problem occurs due to how Windows handles this pool of ports. Windows will put the port into a timeout status for a period of time before it makes the port available for reuse and the default timeout in Windows is 4 minutes! Further, the size of the available pool of ports is only about 16,000 ports in the later versions of Windows. That may sound like a lot of ports, but the speed of modern computers makes it possible, and even likely, that certain operations, such as the outline APIs, that call Essbase many, many times to get information would be subject to this issue. Frankly, we see this issue quite often with both VB and the Java Essbase Outline Extractors.
We brought this issue to the attention of the Java API team and assisted them by testing a prerelease version of the Java API jars. I am happy to report the fix was released with Essbase 11.1.2.3.502. In addition, there is a new essbase.properties setting that allows you to turn the optimization on or off:
olap.system.socketoptimization=false
It is our understanding that this optimization is turned on by default. I also checked the default essbase.properties files shipped with both Essbase 11.1.2.3.502 and 11.1.2.4 and did not see that setting in those files. It may be one of those settings that is there in case it messes something else up. The work of our own Jay Zuercher in our labs and searching Oracle Support seems to have confirmed that thought. There is apparently an issue where EIS drill-through reports don't work in Smart View if socket optimization is turned on. It is documented in Oracle Support Doc ID 1959533.1.
There is also another undocumented essbase.properties setting:
olap.server.socketIdleTime
According to Oracle development, this value defaults to 300 ms but there should be little need to ever change it. The only reason it is there is to tune socket optimization in case more than 2 sockets are used per Java API session.
Jay also tested the 11.1.2.4 version in our labs with the Next Generation Outline Extractor. With the default settings, one large test outline we have, "BigBad", with about 120,000 members in it, extracted in 1 minute and 50 seconds. With socket optimization turned off, the same outline was only about 25% complete after 2 hours. In summary, this fix will be very useful for a lot of Oracle customers.
This issue, which often manifested itself with errors in the Essbase error 10420xx range, was caused by how the Essbase Java API communicated with the server. In essence, whenever a piece of information was needed, the Essbase Java API grabbed a port from the pool of available ports, did its business, and then released the port back to the pool. That doesn’t sound bad, but the problem occurs due to how Windows handles this pool of ports. Windows will put the port into a timeout status for a period of time before it makes the port available for reuse and the default timeout in Windows is 4 minutes! Further, the size of the available pool of ports is only about 16,000 ports in the later versions of Windows. That may sound like a lot of ports, but the speed of modern computers makes it possible, and even likely, that certain operations, such as the outline APIs, that call Essbase many, many times to get information would be subject to this issue. Frankly, we see this issue quite often with both VB and the Java Essbase Outline Extractors.
We brought this issue to the attention of the Java API team and assisted them by testing a prerelease version of the Java API jars. I am happy to report the fix was released with Essbase 11.1.2.3.502. In addition, there is a new essbase.properties setting that allows you to turn the optimization on or off:
olap.system.socketoptimization=false
It is our understanding that this optimization is turned on by default. I also checked the default essbase.properties files shipped with both Essbase 11.1.2.3.502 and 11.1.2.4 and did not see that setting in those files. It may be one of those settings that is there in case it messes something else up. The work of our own Jay Zuercher in our labs and searching Oracle Support seems to have confirmed that thought. There is apparently an issue where EIS drill-through reports don't work in Smart View if socket optimization is turned on. It is documented in Oracle Support Doc ID 1959533.1.
There is also another undocumented essbase.properties setting:
olap.server.socketIdleTime
According to Oracle development, this value defaults to 300 ms but there should be little need to ever change it. The only reason it is there is to tune socket optimization in case more than 2 sockets are used per Java API session.
Jay also tested the 11.1.2.4 version in our labs with the Next Generation Outline Extractor. With the default settings, one large test outline we have, "BigBad", with about 120,000 members in it, extracted in 1 minute and 50 seconds. With socket optimization turned off, the same outline was only about 25% complete after 2 hours. In summary, this fix will be very useful for a lot of Oracle customers.
Categories: BI & Warehousing