国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

oracle - mysql如何將group by的行數據轉為列

瀏覽:65日期:2022-06-15 14:25:01

問題描述

原始數據表如下

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;

相關文章:
主站蜘蛛池模板: 亚洲欧美日韩综合在线一区二区三区 | 免费久草 | 日韩精品网 | 青青草色久综合网 | 欧美怡红院在线观看 | 国内自拍2020 | 欧美亚洲另类久久综合 | 国产一级真人毛爱做毛片 | 亚洲欧美成人在线 | 99精品国产成人一区二区在线 | 加勒比综合 | 日韩毛片欧美一级a网站 | 欧美一区二区视频三区 | 精品国产三级v | 亚洲 欧美 日韩中文字幕一区二区 | 亚洲综合国产 | 亚洲第一视频在线观看 | 欧美大片一区二区三区 | 成年女人毛片免费视频永久vip | 午夜影院黄色 | 国产一级性生活 | 午夜精品成人毛片 | 欧美一级毛片日本 | 高清色黄毛片一级毛片 | 男女视频在线观看免费 | 黄色三级网站免费 | 国产精品99久久久 | 国产亚洲人成a在线v网站 | 中文字幕有码视频 | 免费一级欧美片片线观看 | 免费观看的毛片手机视频 | 日韩视频在线观看一区二区 | 一本高清| 天天摸天天爽视频69视频 | 一区二区三区四区视频在线 | 亚洲国产高清在线 | 亚洲精品综合久久中文字幕 | 97精品国产福利一区二区三区 | 国产精品一久久香蕉国产线看 | 国产精品不卡 | 男人的天堂久久精品激情 |