Я пытаюсь отобразить все строки из одной таблицы, а также SUM / AVG результаты в одном столбце, что является результатом предложения where.Это, вероятно, не имеет особого смысла, поэтому позвольте мне объяснить.
Мне нужно отобразить отчет о всех сотрудниках ...
SELECT Employees.Name, Employees.Extension
FROM Employees;
--------------
| Name | Ext |
--------------
| Joe | 123 |
| Jane | 124 |
| John | 125 |
--------------
... и присоединить некоторую информацию изТаблица PhoneCalls ...
--------------------------------------------------------------
| PhoneCalls Table |
--------------------------------------------------------------
| Ext | StartTime | EndTime | Duration |
--------------------------------------------------------------
| 123 | 2010-09-05 10:54:22 | 2010-09-05 10:58:22 | 240 |
--------------------------------------------------------------
SELECT Employees.Name,
Employees.Extension,
Count(PhoneCalls.*) AS CallCount,
AVG(PhoneCalls.Duration) AS AverageCallTime,
SUM(PhoneCalls.Duration) AS TotalCallTime
FROM Employees
LEFT JOIN PhoneCalls ON Employees.Extension = PhoneCalls.Extension
GROUP BY Employees.Extension;
------------------------------------------------------------
| Name | Ext | CallCount | AverageCallTime | TotalCallTime |
------------------------------------------------------------
| Joe | 123 | 10 | 200 | 2000 |
| Jane | 124 | 20 | 250 | 5000 |
| John | 125 | 3 | 100 | 300 |
------------------------------------------------------------
Теперь я хочу отфильтровать некоторые строки, включенные в вычисления SUM и AVG ...
WHERE PhoneCalls.StartTime BETWEEN "2010-09-12 09:30:00" AND NOW()
... что будетв идеале таблица должна выглядеть примерно так:
------------------------------------------------------------
| Name | Ext | CallCount | AverageCallTime | TotalCallTime |
------------------------------------------------------------
| Joe | 123 | 5 | 200 | 1000 |
| Jane | 124 | 10 | 250 | 2500 |
| John | 125 | 0 | 0 | 0 |
------------------------------------------------------------
Обратите внимание, что Джон не совершал никаких звонков в этом диапазоне дат, поэтому его общее количество вызовов CallCount равно нулю, но он все еще находится в списке результатов.Кажется, я не могу понять, как вести записи, подобные записям Джона, в списке.Когда я добавляю предложение WHERE, эти записи отфильтровываются.
Как создать оператор выбора, который отображает всех сотрудников и только SUMs / AVGs значения, возвращаемые из предложения WHERE?