oracle - mysql如何將group by的行數(shù)據(jù)轉(zhuǎn)為列
問(wèn)題描述
原始數(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為例,可以說(shuō)說(shuō)這類(lèi)問(wèn)題的解決思路嗎?比如統(tǒng)計(jì)兩個(gè)月的數(shù)據(jù),那么就會(huì)有60行轉(zhuǎn)為60列,是否存在效率的瓶頸
問(wèn)題解答
回答1:select sum(money) s,name,date_format(time,’%Y-%m-%d’) d from table group by name,d;然后根據(jù)這里轉(zhuǎn)換
回答2:非要用sql做的話(huà),得寫(xiě)存儲(chǔ)過(guò)程,然后創(chuàng)建個(gè)臨時(shí)表了。沒(méi)必要,把數(shù)據(jù)取出來(lái)后用服務(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寫(xiě)法因?yàn)橹恍枰頀呙枰淮危虼艘话闱闆r下不存在性能問(wèn)題,除非是特別大的表。
這種寫(xiě)法本身只是一個(gè)解決思路,如果列不固定的話(huà),可以在應(yīng)用端通過(guò)php或java動(dòng)態(tài)生成sql語(yǔ)句。
回答5:寫(xiě)個(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)文章:
1. css - 新手做響應(yīng)式布局, 斷點(diǎn)過(guò)后右側(cè)出現(xiàn)空白,求幫助,謝謝。2. python - 啟動(dòng)Eric6時(shí)報(bào)錯(cuò):’qscintilla_zh_CN’ could not be loaded3. javascript - vue 怎么渲染自定義組件4. javascript - 關(guān)于<a>元素與<input>元素的JS事件運(yùn)行問(wèn)題5. mysql - 查詢(xún)字段做了索引為什么不起效,還有查詢(xún)一個(gè)月的時(shí)候數(shù)據(jù)都是全部出來(lái)的,如果分拆3次的話(huà)就沒(méi)問(wèn)題,為什么呢。6. mysql - 記得以前在哪里看過(guò)一個(gè)估算時(shí)間的網(wǎng)站7. 大家好,我想請(qǐng)問(wèn)一下怎么做搜索欄能夠搜索到自己網(wǎng)站的內(nèi)容。8. ID主鍵不是自增的嗎 為什么還要加null9. MySQL中的enum類(lèi)型有什么優(yōu)點(diǎn)?10. python - 安裝pyspider時(shí)出錯(cuò):No space left on device:
