У меня есть стол orders (order_id, order_processed_date)
.Я хочу, чтобы количество заказов в месяц за последние 12 месяцев.Если в каком-либо месяце есть 0 заказов, то он должен вывести 0.
Примерно так:
Total Orders | Month
-----------------------
2 | OCT 2018
3 | SEP 2018
0 | AUG 2018
0 | JUL 2018
1 | JUN 2018
0 | MAY 2018
0 | APR 2018
0 | MAR 2018
5 | FEB 2018
5 | JAN 2018
0 | DEC 2017
0 | NOV 2017
Я уже искал на этом сайте и получил несколько запросов, но не нашел точного решения для этого,Я получаю результат, используя запрос ниже, но у него нет года:
SELECT
SUM(IF(month = 'Jan', total, 0)) AS 'Jan',
SUM(IF(month = 'Feb', total, 0)) AS 'Feb',
SUM(IF(month = 'Mar', total, 0)) AS 'Mar',
SUM(IF(month = 'Apr', total, 0)) AS 'Apr',
SUM(IF(month = 'May', total, 0)) AS 'May',
SUM(IF(month = 'Jun', total, 0)) AS 'Jun',
SUM(IF(month = 'Jul', total, 0)) AS 'Jul',
SUM(IF(month = 'Aug', total, 0)) AS 'Aug',
SUM(IF(month = 'Sep', total, 0)) AS 'Sep',
SUM(IF(month = 'Oct', total, 0)) AS 'Oct',
SUM(IF(month = 'Nov', total, 0)) AS 'Nov',
SUM(IF(month = 'Dec', total, 0)) AS 'Dec'
FROM (SELECT DATE_FORMAT(order_processed_date, '%b') AS month,
COUNT(order_id) as total
FROM orders
WHERE order_processed_date <= NOW() and order_processed_date >=
Date_add(Now(),interval - 12 month)
GROUP BY DATE_FORMAT(order_processed_date, '%m-%Y')) as sub
Может кто-нибудь помочь мне дать мне результат, как мне требуется.