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
8
Medium Priority
?
3,965 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
[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
  • 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
Learn how to optimize MySQL for your business need

With the increasing importance of apps & networks in both business & personal interconnections, perfor. has become one of the key metrics of successful communication. This ebook is a hands-on business-case-driven guide to understanding MySQL query parameter tuning & database perf

 
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
 
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 70

Expert Comment

by:Scott Pletcher
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 70

Accepted Solution

by:
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]
        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

Fill in the form and get your FREE NFR key NOW!

Veeam® is happy to provide a FREE NFR server license to certified engineers, trainers, and bloggers.  It allows for the non‑production use of Veeam Agent for Microsoft Windows. This license is valid for five workstations and two servers.

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…

705 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