Итак, я пытаюсь создать сводную таблицу с запросом SQL.В настоящее время я делаю этот процесс в листах, но хотел бы сделать его немного менее болезненным.
ip domain type date provider type_of_event number_of_events
999 mail.com normal 2018-08-31 orange abuse 12
999 mail1.com normal 2018-08-30 orange abuse 11
999 mail1.com normal 2018-08-29 orange abuse 13
999 mail.com normal 2018-08-31 orange abuse 10
И я бы хотел, чтобы это было так
Domain 2018-08-29 2018-08-30 2018-08-31 Grand Total
mail.com 22 22
mail1.com 13 11 24
У меняпроблема с форматированием, так как большинство примеров, которые я обнаружил, имеют стационарные поля, и тогда даты будут всегда меняться, но мне нужно, чтобы это отображало текущее поле, над которым ведется работа.Который всегда будет с шагом 3 дня.Мне нужно, чтобы он также ссылался на type_of_event, поскольку в примере показан только один тип, но у меня есть несколько в этой же базе данных.
Этот вопрос отличается от других тем, что у меня нет нескольких таблиц, из которых поступают эти данные.Все эти данные находятся в одной таблице.Я не понимаю, как может помочь сводное соединение, когда мне нечего присоединиться?
Итак, использование этого
SELECT CONCAT('SELECT
domain,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 3 DAY))
AS `', CURRENT_DATE() - INTERVAL 3 DAY, '`,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 2 DAY))
AS `', CURRENT_DATE() - INTERVAL 2 DAY, '`,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 1 DAY))
AS `', CURRENT_DATE() - INTERVAL 1 DAY, '`,
SUM(number_of_events) AS `Grand Total`
FROM signal_spam
GROUP BY domain;'
) AS theQuery;
Дает мне
+----------------------------------------------------------------------------
-----------------------------------------------------------------------------
-
-----------------------------------------------------------------------------
-
-----------------------------------------------------------------------------
-
-----------------------------------------------------------------------------
-
----------------+
| theQuery
|
+----------------------------------------------------------------------------
-----------------------------------------------------------------------------
-
------------------------------------------------------------------------------
------------------------------------------------------------------------------
------------------------------------------------------------------------------
----------------+
| SELECT
domain,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 3 DAY))
AS `2018-09-11`,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 2 DAY))
AS `2018-09-12`,
SUM(number_of_events * (date_of_event = CURRENT_DATE() - INTERVAL 1 DAY))
AS `2018-09-13`,
SUM(number_of_events) AS `Grand Total`
FROM signal_spam
GROUP BY domain; |
+----------------------------------------------------------------------------
-----------------------------------------------------------------------------
-
----------------------------------------------------------------------------
--
-----------------------------------------------------------------------------
-
-----------------------------------------------------------------------------
-
----------------+
1 row in set (0.00 sec)
ЕслиЯ удаляю конкат, я не получаю счет в строках, только общий итог, и никакая дата не указана
+------------------------------------+---------------------------------------
+---------------------------------------+------------------------------------
-
--+-------------+
| domain | ', CURRENT_DATE() - INTERVAL 3 DAY, '
|
', CURRENT_DATE() - INTERVAL 2 DAY, ' | ', CURRENT_DATE() - INTERVAL 1 DAY, '
| Grand Total |
+------------------------------------+---------------------------------------
+---------------------------------------+------------------------------------
-
--+-------------+
| 0.pool. | 0
|
0 | 0 | 258 |
| 143.com | 0
|
0 | 0 | 2 |