午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

oracle - mysql如何將group by的行數(shù)據(jù)轉(zhuǎn)為列

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

問題描述

原始數(shù)據(jù)表如下

idnamemoneytime1mike62016-09-01 12:58:002mike102016-09-01 13:52:563leo102016-09-02 00:05:054mike62016-09-03 08:06:05

希望轉(zhuǎn)制后的數(shù)據(jù)表如下

name2016-09-012016-09-022016-09-03mike1606leo0100

以demo為例,可以說說這類問題的解決思路嗎?比如統(tǒng)計(jì)兩個(gè)月的數(shù)據(jù),那么就會(huì)有60行轉(zhuǎn)為60列,是否存在效率的瓶頸

問題解答

回答1:

select sum(money) s,name,date_format(time,’%Y-%m-%d’) d from table group by name,d;然后根據(jù)這里轉(zhuǎn)換

回答2:

非要用sql做的話,得寫存儲(chǔ)過程,然后創(chuàng)建個(gè)臨時(shí)表了。沒必要,把數(shù)據(jù)取出來后用服務(wù)端去做吧。效率高很多。

回答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 給的就是典型的行轉(zhuǎn)列SQL寫法因?yàn)橹恍枰頀呙枰淮危虼艘话闱闆r下不存在性能問題,除非是特別大的表。

這種寫法本身只是一個(gè)解決思路,如果列不固定的話,可以在應(yīng)用端通過php或java動(dòng)態(tài)生成sql語句。

回答5:

寫個(gè)生成腳本的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中間段最后一個(gè)逗號(hào)記得去掉回答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;

相關(guān)文章:
主站蜘蛛池模板: 激情网站 | 新97超碰 | 91精品国产一区二区 | www午夜 | 国产成人在线免费观看视频 | 在线观看国产视频 | 99免费在线观看视频 | 国产欧美成人 | 国产一级精品视频 | 国产黄色片在线免费观看 | 午夜在线观看影院 | 在线播放成人 | 亚洲一区二区在线播放 | 免费在线视频一区二区 | 国产激情综合 | 性色视频在线观看 | 日本在线观看网址 | 亚洲视频一区在线观看 | 亚欧洲精品视频 | 一曲二曲三曲在线观看中文字幕动漫 | 国产精品久久久久9999 | 欧美视频一区二区在线观看 | 在线看日韩av | 日韩精品在线视频观看 | 久久天堂精品 | 91网站免费在线观看 | 自拍 亚洲 欧美 | 国产成人高清 | 999久久久久久久久6666 | 亚洲人在线| 国产午夜精品理论片 | 欧美一区二区不卡视频 | 久久久久免费 | 九一在线免费观看 | 黄色a级大片 | 狠狠草视频 | 69天堂网 | 黄色亚洲视频 | 成人免费观看视频 | 看真人毛片 | 国产日韩在线视频 |