首页 > 数据库 > mysql教程 > mysql年月分组语句_MySQL

mysql年月分组语句_MySQL

WBOY
发布: 2016-06-01 13:29:40
原创
1109 人浏览过

bitsCN.com

mysql年月分组语句

 

Java代码  

SELECT count(DISTINCT(a.rect_id)) zcount, a.job_dept,   

         DATE_FORMAT(submit_date, '%Y-%m') zsubmit_date  

FROM  

        表名 a  

WHERE  

       a.statu = 3  

       AND a.rstatu = 2  

       AND a.job_dept IN ('19', '20', '21')  

GROUP BY  

       a.job_dept,  

       DATE_FORMAT(submit_date, '%Y-%m')  

 其中关键在于DATE_FORMAT(submit_date, '%Y-%m')对时间年月进行了分组排序

 

Java代码  

SELECT  

         zsubmit_date,  

         MAX(CASE WHEN job_dept = '19' THEN zcount ELSE 0 END ) 19zcount,  

         MAX(CASE WHEN job_dept = '20' THEN zcount ELSE 0 END ) 20zcount,  

         MAX(CASE WHEN job_dept = '21' THEN zcount ELSE 0 END ) 21zcount  

FROM  

     (  

       SELECT   

           count(DISTINCT(a.rect_id)) zcount, a.job_dept,   

           DATE_FORMAT(submit_date, '%Y-%m') zsubmit_date  

       FROM  

            表名 a  

       WHERE  

           a.statu = 3  

           AND a.rstatu = 2  

           AND a.job_dept IN ('19', '20', '21')  

       GROUP BY  

       a.job_dept,  

       DATE_FORMAT(submit_date, '%Y-%m')  

     ) q  

GROUP BY  

     zsubmit_date  

 以上是mysql的列转行。其中关键点是case when的用法,用其来完成列转行的操作。

 

 

 

bitsCN.com
相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板