Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
Solved

# Using ISNULL with GROUP BY

Posted on 2008-06-18
Medium Priority
3,965 Views
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]
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]
WHERE fldPriorityUID = 42
GROUP BY Region
0
Question by:looper8
[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
• 2
• 2
• 2
• +1

LVL 75

Expert Comment

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

SELECT region,[Region])
WHERE fldPriorityUID = 42
GROUP BY Region
0

LVL 75

Expert Comment

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

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

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]
WHERE fldPriorityUID = 42
GROUP BY Region
0

LVL 2

Expert Comment

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 70

Expert Comment

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

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 70

Accepted Solution

Scott Pletcher earned 1500 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]
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

Question has a verified solution.

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

I have a large data set and a SSIS package. How can I load this file in multi threading?
Windocks is an independent port of Docker's open source to Windows.   This article introduces the use of SQL Server in containers, with integrated support of SQL Server database cloning.
Viewers will learn how the fundamental information of how to create a table.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…
###### Suggested Courses
Course of the Month6 days, 7 hours left to enroll