zoukankan      html  css  js  c++  java
  • Mysql 行转列

    select username,count(1) from T_CheckData group by username;
    
    /*=====确定列 第一种=====*/
    select sum(case username when '郭二' then 1 else 0 END) as 郭二,
    sum(case username when '张三' then 1 else 0 END) as 张三,
    sum(case username when '李四' then 1 else 0 END) as 李四,
    sum(case username when '王五' then 1 else 0 END) as 王五
     from T_CheckData ;
    
    /*=====确定列 第二种=====*/
    select sum(if(username='郭二',1,0)) as 郭二,
    sum(if(username='张三',1,0)) as 张三,
    sum(if(username='李四',1,0)) as 李四,
    sum(if(username='王五',1,0)) as 王五
     from T_CheckData ;
    
    
    /*=====不确定列=====*/
    /*=====【username】替换为你想要的动态列值=====*/
    /*=====【state】替换为用于合计的数值=====*/
    /*=====【weight】替换为你的分类值(一般为日期)=====*/
    /*=====【T_CheckData】替换为表名=====*/
    SET @EE='';
    set @str_tmp='';
    SELECT @EE:=CONCAT(@EE,'SUM(IF(username='',username,''',',state,0)) AS ',username,',') as aa into @str_tmp FROM (SELECT DISTINCT username FROM T_CheckData) A order by length(aa) desc limit 1; 
    SET @QQ=CONCAT('SELECT ifnull(T_CheckData.weight,'total') as 分类,',LEFT(@str_tmp,char_length(@str_tmp)-1),'  ,SUM(state) AS TOTAL FROM T_CheckData GROUP BY weight WITH ROLLUP');
    PREPARE stmt  FROM @QQ; 
    EXECUTE stmt ;
    deallocate prepare stmt;
  • 相关阅读:
    每日总结
    每日总结
    每日总结
    每日总结
    每日总结
    每日总结
    每日总结
    实现微信小程序和支付宝小程序二维码合并
    Solr教程:1.下载和安装
    如何生成漫画风图片无需下载APP无需PS无需电脑
  • 原文地址:https://www.cnblogs.com/shengwei/p/5706919.html
Copyright © 2011-2022 走看看