Соедините две таблицы на дату - PullRequest
2 голосов
/ 11 марта 2020

У меня есть две таблицы, к которым мне нужно присоединиться, и мне нужно получить данные, которые я могу использовать для построения графика.

Примеры данных для двух таблиц:

**table1**

month       planned_hours
2019-10-01  24
2020-01-01  67
2019-02-01  12

**table2**
date         hrs_consumed
2019-12-07   7
2019-09-09   3
2019-10-12   4
2019-02-01   5
2019-10-11   4

Я пытался следующий запрос:

SELECT 
  a.date as month1,
  a.hrs as planned_hours,
  a.mon_hrs as actual_hours 
FROM (
  SELECT 
    sum(t1.hrs_consumed) as hrs,
    t1.date,
    t2.mon_hrs
  FROM booking t1
  LEFT JOIN monthly_plan t2 
  ON month(t1.date) = month(t2.mon)
  UNION
  SELECT 
    t2.mon_hrs,
    t2.mon as date,
    sum(t1.hrs_consumed) as hrs
  FROM booking t1
  RIGHT JOIN monthly_plan t2 
  ON month(t1.date) = month(t2.mon)) a

Я получил следующий вывод из запроса:

month1      planned_hrs  actual_hrs
2019-10-01  24           8
2019-10-01  24           8

Вывод, который я хочу получить:

month1   planned_hrs   actual_hrs
10-2019  24            8
12-2019  0             7
08-2019  0             3
01-2020  67            0
02-2019  12            5

1 Ответ

0 голосов
/ 11 марта 2020

Вы можете объединить отдельные месяцы с таблицами и агрегировать:

SELECT 
  t.month,
  COALESCE(MAX(t1.planned_hours), 0) planned_hours,
  COALESCE(SUM(hrs_consumed), 0) actual_hrs
FROM (
  SELECT DATE_FORMAT(month, "%m-%Y") month FROM table1
  UNION
  SELECT DATE_FORMAT(date, "%m-%Y") FROM table2
) t
LEFT JOIN table1 t1 ON t.month = DATE_FORMAT(t1.month, "%m-%Y")
LEFT JOIN table2 t2 ON t.month = DATE_FORMAT(t2.date, "%m-%Y")
GROUP BY t.month

См. Демоверсию . Результаты:

| month   | planned_hours | actual_hrs |
| ------- | ------------- | ---------- |
| 01-2020 | 67            | 0          |
| 02-2019 | 12            | 5          |
| 09-2019 | 0             | 3          |
| 10-2019 | 24            | 8          |
| 12-2019 | 0             | 7          |
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...