一、有些統計頁面需要達到如下效果(按照月份分組計算數據)
二、在這里需要使用到mysql的幾個函數
1、DATE_ADD() 函數向日期添加指定的時間間隔。
語法:
DATE_ADD(date,INTERVAL expr unit)
date 參數是合法的日期表達式。expr 參數是您希望添加的時間間隔。unit是指定的時間間隔類型單位。
unit參數可以是下列值:
unit值
MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH
舉例如下:
2、DATE_SUB() 函數從日期減去指定的時間間隔。
語法:
DATE_SUB(date,INTERVAL expr unit)
date 參數是合法的日期表達式。expr 參數是您希望添加的時間間隔。unit是指定的時間間隔類型單位。
所用的unit單位和上面的DATE_ADD()完全一致
3、DAYOFYEAR(date)
date 參數是合法的日期表達式
返回date在一年中的日數, 在1到366范圍內。
三、先看看執行結果,然后在詳解sql
SELECT
left(temp.date,7) as dateAbscissa,
IFNULL(u.unmber,0) as thisYearCost
from(
SELECT date_add(DATE_SUB(CURDATE(),INTERVAL dayofyear(now())-1 DAY), interval numlist.id month) AS 'date' FROM
(
SELECT * from
(SELECT i AS id FROM num ) a
where a.id <=11
) AS numlist
WHERE adddate(DATE_SUB(CURDATE(),INTERVAL dayofyear(now())-1 DAY), interval numlist.id month)<=
concat(YEAR(now()),'-12-31')) temp
LEFT JOIN
(
SELECT
left(c.statistics_date,7) AS udate,
SUM(c.operation_number) as unmber
FROM
t_hospitalization_operation c
WHERE
1 = 1
GROUP BY left(c.statistics_date,7)
) u on left(temp.date,7) = u.udate ORDER BY temp.date
結果如下
四、分步解釋sql
前提:需要一張中間表num,數據如下
然后LEFT JOIN 本身的數據表,既可達到效果,
# 按照天數統計
SELECT
temp.date as dateAbscissa,
IFNULL(u.singleDiseasesNum,0) as singleDiseasesNum,
IFNULL(u.multidisciplinaryNum,0) as multidisciplinaryNum
from( SELECT DATE_ADD((date_add(date_add(last_day(now()),interval 1 day),interval -1 month)),INTERVAL numlist.id DAY)AS 'date' FROM
(
SELECT * from
(SELECT i AS id FROM num ) a
where a.id <=30
) AS numlist
) temp
LEFT JOIN
(
SELECT
DATE(c.create_time) AS udate,
COUNT(if( c.audit_opinion='3' ,1,NULL) )as singleDiseasesNum,
COUNT(if( c.audit_opinion='4' ,1,NULL) )as multidisciplinaryNum
FROM
t_mdt_apply_list c
WHERE
1 = 1
GROUP BY DATE(c.create_time)
) u on DATE(temp.date) = u.udate ORDER BY temp.date
參考:https://blog.csdn.net/JavaReact/article/details/79994555
仍在不斷學習中,歡迎大家留言