Различные варианты группировки и подсчета значений

Продолжая тему SQL-запросов, хочу показать еще один запрос. Задача стоит в том, чтобы подсчитать количество пришедших клиентов по всем заявкам. В нашем случае флаг клиента — это значение idbid > 0. Вот, собственно, такой запрос получился: SELECT count( * ) , count( idbid ) , count( idbid >0 ) , count( if( idbid >0, 1, NULL ) ) , sum( idbid ) , sum( idbid >0 ) , idbid >0 , operatorbid FROM ххххххх GROUP BY operatorbid ? Здесь из всех вариантов подсчета правильные только два:

  1. count( if( idbid >0, 1, NULL ) ). Здесь, если idbid не больше нуля, то возвращается null (на каждой итерации строки). Важно, чтобы именно null, так как ноль тоже учитывается в подсчете, если выполняется count(), а не sum(). Именно поэтому подсчеты 1, 2 и 3 возвращают одно и то же. Как видите, вариант idbid >0 возвращает 0 или 1, что не подходит нам, так как 0 !== null и возвращает общее количество колонок.
  2. sum( idbid >0 ). Этот вариант так же возвращает корректное значение, так как подсчитывает сумму только вариантов 0 или 1, что в сумме дает правильное количество клиентов. А вот просто sum( idbid) нам не годится, так как возвращает абсолютное значение суммы всех ID-шников найденных клиентов, а они все больше единицы (в итоге мы получаем огромное число).