?
Solved

SSRS Chart data and selections with no entries

Posted on 2014-10-02
4
Medium Priority
?
375 Views
Last Modified: 2014-10-03
Hello Experts Exchange
I am developing a SSRS Report that has categories and a sum of Total hours.  I select the data, that is OK, but I have categories that have no data against them but I want them to show up on the chart as a zero value.

I have a table of data that lists all the categories.

Is there a way I can select the categories that have no data for them and set the value to zero and still keep my categories with data too?

Regards

SQLSearcher
0
Comment
Question by:SQLSearcher
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
4 Comments
 
LVL 22

Expert Comment

by:Nico Bontenbal
ID: 40358842
I suppose the data is in a SQL Server database. I think the easiest way is to use an outer join in your query to make sure all the categories are always returned in your dataset (with a zero value, if there is no data). This can be done with an outer join. See:
http://technet.microsoft.com/en-us/library/ms187518(v=sql.105).aspx
0
 

Author Comment

by:SQLSearcher
ID: 40358872
Hello Nicobo
This is the SQL I have, but its not working as there is one category that is not coming back as zero.

SELECT   a.[Category], Isnull(SUM(b.[Total Lost Hours]),0) AS [Total Lost Hours]
FROM  [dbo].[MachineLosses_Level1] a       
left outer join MachineLosses_New b on a.[Category] = b.[level 1]
WHERE     ([File Name] IN ('Htr01 (581)', 'Htr04 (584)', 'Htr3 (583)', 'Htr9 (589)', 'UKL (593)'))
GROUP BY a.[Category]
ORDER BY [Total Lost Hours] DESC

Open in new window


Can you see where my error is?

Regards

SQLSearcher
0
 
LVL 22

Accepted Solution

by:
Nico Bontenbal earned 2000 total points
ID: 40359169
The outer join makes sure all the categories are in the result. But the where clause filters the empty categories out of the result. You can solve this by using a subquery. Something like this:
select
    [Category], 
    ISNULL([Total Lost Hours],0) AS [Total Lost Hours]
from
    [dbo].[MachineLosses_Level1] cat left join
    (SELECT   a.[Category], Isnull(SUM(b.[Total Lost Hours]),0) AS [Total Lost Hours]
    FROM  [dbo].[MachineLosses_Level1] a       
    left outer join MachineLosses_New b on a.[Category] = b.[level 1]
    WHERE     ([File Name] IN ('Htr01 (581)', 'Htr04 (584)', 'Htr3 (583)', 'Htr9 (589)', 'UKL (593)'))
    GROUP BY a.[Category]
    ) sub on cat.[Category] = sub.[Category]
ORDER BY 
    [Total Lost Hours] DESC

Open in new window


Google for "derived table subquery sql server" for more information on the subject. There is an example on this page:
http://msdn.microsoft.com/en-us/library/ms177634.aspx
It's example I.
0
 

Author Closing Comment

by:SQLSearcher
ID: 40359292
Thank you very much for your help.
0

Featured Post

Percona Live Europe 2017 | Sep 25 - 27, 2017

The Percona Live Open Source Database Conference Europe 2017 is the premier event for the diverse and active European open source database community, as well as businesses that develop and use open source database software.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Ever wondered why sometimes your SQL Server is slow or unresponsive with connections spiking up but by the time you go in, all is well? The following article will show you how to install and configure a SQL job that will send you email alerts includ…
It is possible to export the data of a SQL Table in SSMS and generate INSERT statements. It's neatly tucked away in the generate scripts option of a database.
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.
Suggested Courses

764 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question