Wednesday, December 19, 2012

SSRS report with click-through detail hosted in PerformancePoint Services

Here's a situation:
You have a Reporting Services report (SQL 2008 or higher) hosted in SharePoint PerformancePoint Services (SHPT 2010 or higher). You are interested in adding a click path to that report which will open a detail report in a new window. How do you do it?

Well, the short answer is, you don't.  Not in PPS, at least.  This can be done in standalone reports but, per Microsoft, this behavior is not supported in PPS.  The referenced URL will NOT open in a new window through SharePoint/PerformancePoint Services.   So.  That's awesome.  Not. 

How did I arrive at this conclusion?

I was working on getting a detail report to open from a PerformancePoint-hosted SSRS Map report.  I wanted the states in my US map to have a clickable action that would open up another SSRS report.  I was initially able to get the report and click-through action to work by using a simple Go To Report action.  But the detail report opened by the Go To Report action comes up in the same browser window -- which could cause some navigational confusion for users.

So I wanted to see if I could force the detail report to open in a new Window - which I could.  Instead of "Go to Report", I used the "Go To URL" action instead.  The technique for this is all over the intarwebz, but I found these two articles to be the most directly useful:
Before you even look at those posts, here are the basic moves:
  • You'll need to assemble a good, working URL for your report -- either in Report Manager or in SharePoint (if you're running in Integrated Mode).  I found this to be the trickiest part.  Hint: you want to open the Report using a ReportViewer.aspx.
  • You'll then need to include that URL in the dataset in your main report.  In my case, I also needed to pass a parameter (hence the second link above).
  • Then you need to set up the Go To URL action using that assembled URL.  Despite what the links say, I cut out the javascript "window.open()" script code -- providing the URL alone did what I needed.

So, delightful.  I had my detail report opening in a new window in the Designer and via Report Manager.  But, as soon as I deployed my newly tricked out reports and tried them in PPS, there was fail.   So I scouted around for a long time and found this: http://go4answers.webhost4life.com/Example/open-window-does-not-work-ssrs-report-20883.aspx

Scroll to the last comment to see my sad discovery.

Is there a workaround?  Yes, but it's lame.   Users can use the right-click menu when clicking on the map report, and select "Open in New Window" or "Open in New Tab" to achieve the same results.  But expecting users to navigate like that is a poor substitute for something that, you know, just works.

So the bottom line is that PPS does not give you 100% "pass-thru" SSRS behavior when using a Reporting Services report type in a dashboard. 

Thursday, December 6, 2012

SQL Server 2012 Data Tools "Gotchas"

I've been working in SQL 2012 the past couple weeks on a new project, and I'm finally getting past the "new car smell"/honeymoon period.  Over the last 2-3 days I've encountered some more subtle and insidious changes of which I'm not a fan. At all. 

To be sure, I am mostly OK with the cosmetic changes in the toolset.  The exception there being SSIS, because I loved how it was all "the light is green, the trap is clean" in 2005 and 2008.  Yeah, it's a little less cartoony now.  But I love cartoons, so that's not exactly value-add to me... Also, I don't see any real difference thus far between BIDS and the spankin' new "SQL Server Data Tools".  Feels like the same thing (subject-are-limited version of Visual Studio) with a new name.

And, you know, I generally expect things to change between software versions.  Especially when you're dealing with Microsoft.  :)   But I feel like anytime a software "upgrade" or new version removes or deprecates commonly used functionality, that's a step in the wrong direction.  

Obviously, there are exceptions.  For instance, since we're talking about MS, I'm quite cool with Windows 8 and its new touchscreen oriented interface.  Because, honestly, do you really love the mouse that much?  Seriously, though, I think it looks great and is very usable once you get over the slight learning curve required to deal with any new OS. 

Where I have problems is with things that are maybe a little more under the covers.  Things that you take for granted because they are integrated into a given piece of software's basic workflow and usability profile.  And this is where I feel like there are shenanigans at play in SQL 2012.

I discovered this week, to my chagrin, that automatic metadata refresh seems to have been surgically removed from the SSIS 2012.  Say you build a data flow including some components you will likely use again in the project -- like, say, a Lookup on a Date dimension.  In the 2005/2008 world, you could copy/paste the component(s) into a new Data Flow, hook them up, and SSIS would update the pasted component's metadata and -- BLAMMO -- reuse!   Right?  Well, not so much in 2012.  It won't automatically refresh any metadata.  Another example:  You create an OLE DB component, drop a SQL query in it and continue on your merry way.  But the DBA changes one of the columns in your from a VARCHAR(50) to a VARCHAR(100).  In 2005, the next time you open the package, SSIS would identify this and prompt you to accept the metadata update so your OLE DB source is in sync.  Handy, yes?  Well, kiss it goodbye.  That's all manual in 2012, from what I'm seeing so far.

A more straightforwardly bald-faced Surgical Feature Removal exists in SSAS, and it SOOOO rubs me the wrong way.   The cube browser in SQL Server Data Tools no longer supports hierarchical display.  That's right: when you browse the cube, your hierarchical dimensions are displayed as a flat table.  I mean, COME ON!  Seriously?  If I wanted a G-D table, I'd write a query!  Microsoft's responses online have mumbled something about "use Excel to view hierarchy-style data", but I'm not trying to hear that, honestly.  Excel is all fine and good for users, but I want a DEVELOPMENT TOOL that has SUPERPOWERS.  Not something that has to be "fixed" or "completed" via Excel.

And that may be just the tip of the iceberg.  I haven't touched SSRS 2012 yet.  And now I'm afraid to.  Between the giant fumble with PowerView (doesn't work with multidimensional?  Really?  Seriously?) and these things I'm encountering, I'm a little bearish on working with SQL 2012 BI stuff. 

How about y'all?  Anything in the SQL 2012  BI toolset sticking in your craw?

Thursday, November 15, 2012

MDX query across multiple Role-Playing Dimensions in SSAS 2008R2

Here is what I would consider to be a magic post:  http://richardlees.blogspot.com/2011/06/linkmember.html

Mr. Lees does the Lord's work here, and surely helped me out of a jam.  I was trying to figure out a way to collect a single measure across multiple role-playing dimensions.   Everything I tried was epic fail, including the solution I initially arrived at which was to create 3 separate queries and let SSRS sort them out....

To set the scene, an example of the problem I was having would be:
- I want to find the numbers of New Widgets, Sold Widgets, and Improper Widgets, by month over the last 12 months (Rolling 12 Month totals).
- In my SSAS cube I have a Measure for Widget Count, and I have 3 role-playing Date dimensions -- Released Date, Sale Date, Inspection Failed Date -- all based on a single Date dimension living in the underlying Data Mart.
- Appropriately filtering and slicing the Widget Count by any of the above dates yields correct results.  But since the cube believes (techically properly, I guess) that those role-playing dimensions are all actually different dimensions, I cannot get a good slicer Axis out of only one of the date dimensions.  So, in a nutshell

In other words, I couldn't get into a single query/dataset all 3 of the desired measures. This was because I really needed to query a single measure across 3 different role-playing dimensions.

So, in comes Mr. Lees.  He introduced me to the magic of LinkMember().  And thus I quickly solved my problem.   LinkMember allowed me to create a Calculated Member that gave me totals aligned with each of the Role Playing Dimensions I was looking at.  Booyah, granny!




Friday, January 27, 2012

Collaboration or Groupthink?

Saw this was posted on Facebook by a colleague at work:
http://www.nytimes.com/2012/01/15/opinion/sunday/the-rise-of-the-new-groupthink.html?_r=2&ref=opinion

The whole notion of calling out "teamwork" as such a basic value kind of gives me a chill.  Goose bumps even... 

I can't speak for you, gentle reader, but I can safely say that the absolute worst work I ever did in either my academic or professional careers was in group projects.  I can recall exactly two projects in the working world where my entire software team met or exceeded my own and our customer's expectations.  The only times I've ever been on "teams" that consistently worked were bands.  And that's only happened like 2-3 times in over a dozen bands. 

I even remember in school thinking that the best possible outcome of group work was usually mediocrity.  The usually random mix of group members and their general engagement levels meant that one or two people in the group would usually take on 85-90% of the work.  I see this pattern echoed in virutally every large company I have consulted or contracted for.

Certainly there are needs which can only be served by teamwork. Huge workloads of all kinds require more resources, which can most usefully be coordinated in teams.  Another dimension would be skill sets required for the work, which may also need to broken down team-wise.  But in terms of a need for teamwork involving more than one mind focused on a single problem (i.e. "brainstorming"), the statistics say that this usually does not result in a better solution.  Note the important exception pointed out by the author about collaboration (specifically remote collaboration, as enabled by technology).    fostering collaboration between nominally independent individuals seems to have significant worth. 

I look at this as the true endgame of the software "collaboration wave" seen in business IT right now.   It's easy to dismiss the buzzword, or consider it a forced mandate for "groupthink."  But empowering knowledge workers with data, allowing them to build ideas and evolve them into useful business tools -- that is a powerful force that is already working.