SSRS Report Performance Thoughts – To calculate on the report, or in your X++ code

by | Updated August 15, 2016 | Development, Dynamics AX, Reporting

For this blog post, I have been thinking about different ways data can be aggregated for SSRS Reports. When doing subtotaling on reports, you generally do an expression that resembles something like this:

=Sum(Fields!someField.Value)

You can also do this type of aggregation for a total in a row based on multiple fields.

Here is the dilemma, is it faster or more efficient to do this type of work on the SSRS report itself, or do it in the Report Data Provider logic (totals in a ROW, not a group subtotal) class logic, and pass the data to SSRS as a field in a table?

My personal feeling on this is that I like to do the work up front (in the X++ code) and pass the final total into the field, instead of doing the calculations on the SSRS report. You will be passing a bit more information to the report (an additional column or two), but you are saving the report from having to do the calculation at render time, which should cause the report to render more quickly.

If you are working with a preprocessed SSRS report, why not do the work first, and make it easy on the report renderer? This concept really is similar in thought to what we teach in X++ Development best practices. Use the aggregate functions to get a record back instead of a loop to do totals (you may loop through THOUSANDS of lines to do your total calculation), or use JOINS instead of nested while selects to get data in select statements. You tend to rely on the database engine to do the work for you instead of the code. Do the same for the report whenever possible, and have the ‘heavy lifting’ completed by the time the data gets to the report.

Please note that I have NOT done any ‘official’ type testing to measure execution time differences, but to me this thought exercise really follows the Development Best Practices that we try to instill in AX Developers, so why not have this flow into report design as well.

I welcome any discussion or feedback on the above.

Related Posts

0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

Upcoming Events

august

12aug10:00 am10:30 amWhy Levridge Grain? How to Achieve Efficient and Accurate Scale Tickets

12aug12:00 pm1:00 pmThe Three Paths to Dynamics 365 Finance and Supply Chain from Dynamics AX

13aug11:00 am12:00 pmConfab with Stoneridge - Livestream - Inspire Keynote Breakdown

19aug10:00 am11:00 amWhat is Levridge? An Overview of the Ultimate Ag Solution

19aug12:00 pm12:30 pmThe Modern Manufacturer - Death by Safety Stock

27aug12:00 pm1:00 pmConfab with Stoneridge - Livestream - Dynamics 365 2020 Wave 2 Preview

september

02sep10:00 am10:30 amThe Modern Manufacturer - Cycle Count Management

09sep10:00 am11:00 amWhat is Levridge? An Overview of the Ultimate Ag Solution

16sep10:00 am10:30 amThe Modern Manufacturer - Product Lifecycle Management

30sep10:00 am10:30 amThe Modern Manufacturer - Return Management

About Stoneridge
Stoneridge Software is a unique Microsoft Gold Partner, with emphasis on partner. With specialties in Microsoft Dynamics 365, Microsoft Dynamics AX, Microsoft Dynamics NAV, Microsoft Dynamics GP and Microsoft Dynamics CRM, we focus on attracting the most knowledgeable experts in the field to our team, and prioritize delivering stellar solutions with maximum impact for your business. At Stoneridge, we are deeply committed to your results. Each engagement is met with a dedicated team, ready to provide thorough, tailored, and expert service. Based in Minnesota, we intentionally “step into your shoes,” wherever you are. We focus on what you care about, and develop trusting, long-term relationships with our clients.

Subscribe To Our Blog

Sign up to get periodic updates on the latest posts.

Thank you for subscribing!

X