oracle - mysql如何将group by的行数据转为列
问题描述
原始数据表如下
idnamemoneytime1mike62016-09-01 12:58:002mike102016-09-01 13:52:563leo102016-09-02 00:05:054mike62016-09-03 08:06:05希望转制后的数据表如下
name2016-09-012016-09-022016-09-03mike1606leo0100以demo为例,可以说说这类问题的解决思路吗?比如统计两个月的数据,那么就会有60行转为60列,是否存在效率的瓶颈
问题解答
回答1:select sum(money) s,name,date_format(time,’%Y-%m-%d’) d from table group by name,d;然后根据这里转换
回答2:非要用sql做的话,得写存储过程,然后创建个临时表了。没必要,把数据取出来后用服务端去做吧。效率高很多。
回答3:create table tt1(id int ,name VARCHAR(100),money FLOAT,time DATETIME)insert into tt1select 1,’mike’,6,’2016-09-01 12:58:00’ UNIONselect 2,’mike’,10,’2016-09-01 13:52:56’ UNIONselect 3,’leo’,10,’2016-09-02 00:05:05’ UNIONselect 4,’mike’,6,’2016-09-03 08:06:05’select name,sum(case when datediff(time,’2016-09-01’)=0 then money else 0 end) as ’2016-09-01’ ,sum(case when datediff(time,’2016-09-02’)=0 then money else 0 end) as ’2016-09-02’ ,sum(case when datediff(time,’2016-09-03’)=0 then money else 0 end) as ’2016-09-03’from tt1 GROUP BY name回答4:
@ch21st 给的就是典型的行转列SQL写法因为只需要表扫描一次,因此一般情况下不存在性能问题,除非是特别大的表。
这种写法本身只是一个解决思路,如果列不固定的话,可以在应用端通过php或java动态生成sql语句。
回答5:写个生成脚本的sql就完了嘛
select 'select name,' union select concat('sum(case when datediff(time,’',date(time),'’)=0 then money else 0 end) as ’',date(time),'’,') a from tt1 group by a union select ' from tt1 group by name;';PS:union中间段最后一个逗号记得去掉回答6:
SELECT name, sum( if(date_format(time,’%Y-%m-%d’) = ’2016-09-01’, money, 0 ) ) AS ’2016-09-01’, sum( if(date_format(time,’%Y-%m-%d’) = ’2016-09-02’, money, 0 ) ) AS ’2016-09-02’, sum( if(date_format(time,’%Y-%m-%d’) = ’2016-09-03’, money, 0 ) ) AS ’2016-09-03’FROM money_table GROUP BY name;
相关文章:
1. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路2. javascript - 小白求解:mac 下如何设置nodejs express的 NODE_NEV 环境变量3. javascript - 实参和形参有哪些通俗的命名吗?尤其形参4. 找一个权威、实战的微信扫码授权登录网站的开发教程或者文章5. mysql5.7 json查询支持6. Python如何考虑代码注入安全?7. javascript - avalon.js ms-on 事件绑定无效 ?8. javascript - 请问一下react-native 布局的时候,尺寸的大小是如何确定的呢?9. javascript - js 修改表格元素的,可以用DOM操作实现吗?10. javascript - jQuery中live事件在移动微信端下没有效果;代码如下