Solved

Using ISNULL with GROUP BY

Posted on 2008-06-18
8
3,417 Views
Last Modified: 2008-06-25
Why does thist first bit of code return zeros when there is no data, but the second bit returns nothing?

SELECT       ''
      , COUNT([Region]) AS [Tot No of Incidents]
        , ISNULL(SUM([On Site < 2 hrs]), 0) AS [On site < 2 hrs]
        , ISNULL(SUM([Fixed < 3.75 hrs]), 0) AS [Fixed < 3.75 hrs]
        FROM tblFireLinkReportsTemp
        WHERE fldPriorityUID = 42

SELECT       Region
        , COUNT([Region]) AS [Tot No of Incidents]
        , ISNULL(SUM([On Site < 2 hrs]), 0) AS [On site < 2 hrs]
        , ISNULL(SUM([Fixed < 3.75 hrs]), 0) AS [Fixed < 3.75 hrs]
        FROM tblFireLinkReportsTemp
        WHERE fldPriorityUID = 42
        GROUP BY Region
0
Comment
Question by:looper8
  • 2
  • 2
  • 2
  • +1
8 Comments
 
LVL 75

Expert Comment

by:Aneesh Retnakaran
ID: 21811078
are u sure there are records matching the second criteria


SELECT region,[Region])
FROM tblFireLinkReportsTemp
WHERE fldPriorityUID = 42
GROUP BY Region
0
 
LVL 75

Expert Comment

by:Aneesh Retnakaran
ID: 21811084
or did u forget to remove the WHERE  condition, cuz, there is logically no difference b/w the first and second
0
 
LVL 2

Expert Comment

by:howyue
ID: 21811089
SELECT '' will always give u a row even ur WHERE clause returns no result, '' is more like a hardcode value
SELECT [column] will not guarantee u a row because if ur WHERE clause returns no result, the [column] will be null
0
 
LVL 1

Author Comment

by:looper8
ID: 21811292
aneeshattingal: I'm trying to code for times when there is no data, so I'm running both bits against an empty table.

howye: I thought that too, but the following still returns no results:

SELECT    ''
      ,   Region
        , COUNT([Region]) AS [Tot No of Incidents]
        , ISNULL(SUM([On Site < 2 hrs]), 0) AS [On site < 2 hrs]
        , ISNULL(SUM([Fixed < 3.75 hrs]), 0) AS [Fixed < 3.75 hrs]
        FROM tblFireLinkReportsTemp
        WHERE fldPriorityUID = 42
        GROUP BY Region
0
Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

 
LVL 2

Expert Comment

by:howyue
ID: 21811321
the only difference in ur query is GROUP BY
with GROUP BY it giv u NULL, without GROUO BY is giv u 0.
however i'm stil tryin to figure out why is it so
0
 
LVL 69

Expert Comment

by:ScottPletcher
ID: 21813352
In the first query, you are asking SQL for an overall COUNT, SUM, etc..  Even if there are no rows in the table, the COUNT() is still a *relevant* result, of 0.

In the second query, you are asking SQL for a count **by region**.  This could easily produce many rows as a result, obviously: one row **per region**.  But, if there are no regions, then there is no **relevant** result, since you explicilty asked for a COUNT, SUM, etc., **only** by region.
0
 
LVL 1

Author Comment

by:looper8
ID: 21814298
Thanks Scott.  Is there then a way I can force the second query to return results (of zero), even though there is no Region in the table?
0
 
LVL 69

Accepted Solution

by:
ScottPletcher earned 500 total points
ID: 21814360
Not directly really.  But could check first and if the table has no matching rows, issue a different query.  For example:

IF EXISTS(SELECT TOP 1 Region FROM tblFireLinkReportsTemp WHERE fldPriorityUID = 42)
BEGIN
-- normal query goes here
SELECT       Region
        , COUNT([Region]) AS [Tot No of Incidents]
        , ISNULL(SUM([On Site < 2 hrs]), 0) AS [On site < 2 hrs]
        , ISNULL(SUM([Fixed < 3.75 hrs]), 0) AS [Fixed < 3.75 hrs]
        FROM tblFireLinkReportsTemp
        WHERE fldPriorityUID = 42
        GROUP BY Region
END --IF
ELSE
BEGIN
-- "special table is empty query" goes here
SELECT       ''
        , 0 AS [Tot No of Incidents]
        , 0 AS [On site < 2 hrs]
        , 0) AS [Fixed < 3.75 hrs]
END --ELSE
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

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

Suggested Solutions

Introduction SQL Server Integration Services can read XML files, that’s known by every BI developer.  (If you didn’t, don’t worry, I’m aiming this article at newcomers as well.) But how far can you go?  When does the XML Source component become …
The Delta outage: 650 cancelled flights, more than 1200 delayed flights, thousands of frustrated customers, tens of millions of dollars in damages – plus untold reputational damage to one of the world’s most trusted airlines. All due to a catastroph…
Via a live example combined with referencing Books Online, show some of the information that can be extracted from the Catalog Views in SQL Server.
Via a live example, show how to setup several different housekeeping processes for a SQL Server.

919 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

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now