MySQL: Как выбрать и отобразить ВСЕ строки из одной таблицы и вычислить сумму предложения where для другой таблицы? - PullRequest
5 голосов
/ 12 октября 2010

Я пытаюсь отобразить все строки из одной таблицы, а также 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?

1 Ответ

7 голосов
/ 12 октября 2010

Использование:

   SELECT e.Name, 
          e.Extension,
          Count(pc.*) AS CallCount, 
          AVG(pc.Duration) AS AverageCallTime, 
          SUM(pc.Duration) AS TotalCallTime
     FROM Employees e
LEFT JOIN PhoneCalls pc ON pc.extension = e.extension
                       AND pc.StartTime BETWEEN "2010-09-12 09:30:00" AND NOW()
 GROUP BY e.Name, e.Extension

Проблема заключается в том, что при использовании OUTER JOIN задание критериев в разделе JOIN применяется до , когда происходит JOIN - подобно производной таблице или встроенному представлению. Предложение WHERE применяется после OUTER JOIN, поэтому, когда вы указали предложение WHERE в таблице как LEFT OUTER JOIN'd, чтобы строки, которые вы все еще хотели видеть, отфильтровываются.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...