Skip to content
Advertisement

USE ELSE 0 doesn’t work as expected in SQL

I have the following SQL query:

SELECT 
    modal_text, 
    COUNT(CASE WHEN ab_group = "control" THEN 1 ELSE 0 END) 
FROM 
    onboarding_modals 
GROUP BY 
    1 
ORDER BY 
    1;

This doesn’t work as expected (it will count more than expected), but when I remove the ELSE 0 in aggregate function, it works as expected:

SELECT 
    modal_text, COUNT(CASE WHEN ab_group = "control" THEN 1  END) 
FROM 
    onboarding_modals 
GROUP BY 
    1 
ORDER BY 
    1;

Could someone explain me why having the ELSE 0 will make it count more data than it should be?

*It will also work if I use ELSE NULL

Advertisement

Answer

Because a COUNT(SomeColumn) doesn’t count the NULL’s in a column.

COUNT(1) or COUNT(*) count the rows.

And so does a COUNT(CASE WHEN x=1 THEN 1 ELSE 0 END)
This has no NULL’s to ignore, because it’s either 1 or 0.

But a CASE WHEN x=1 THEN 1 END
is just the implicit shorter syntax for
CASE WHEN x=1 THEN 1 ELSE NULL END

So it’s normal to COUNT without the ELSE.

COUNT(DISTINCT CASE WHEN x=1 THEN t.ID END)

If you do want to use an ELSE, then do it with a SUM

SUM(CASE WHEN x=1 THEN 1 ELSE 0 END)
User contributions licensed under: CC BY-SA
9 People found this is helpful
Advertisement