內存數據庫中列轉行的應用,h2中列轉行,hsqldb中列轉行

其實列轉行是比較簡單的用sum和decode函數就可以了,但是我遇到的項目,不知道數據誰設計的居然字段裏面還設計成long類型,此long類型與java中的不同,oracle中的long是指可變長二進制數據,最長2G,哎沒辦法只好轉換了。

以下是hsqldb的轉換,用到了轉換函數convert,可以將long類型的轉換爲double類型,其中d.value是long類型,status是int類型,所以value需要轉換

 SELECT P.NAME,P.ID,

 SUM(DECODE(D.K_NAME,'a',convert(d.value,SQL_DOUBLE),NULL)) AS a1,

 SUM(DECODE(D.K_NAME,'a',convert(d.value,SQL_DOUBLE),NULL)) AS b1, 

 SUM(DECODE(D.K_NAME,'a',D.STATUS,NULL)) AS a1_status,

 SUM(DECODE(D.K_NAME,'a',D.STATUS,NULL)) AS b1_status 

  FROM  

 P LEFT JOIN 

 D ON P.ID=D.id

 WHERE a  IN ('a','b')  

  GROUP BY P.NAME,P.ID  

 ORDER BY decode(a,null,0,a) DESC LIMIT 0,10

h2是內存數據庫,跟hsqldb類似,但是性能好像沒有hsqldb穩定

SELECT P.NAME,P.ID,

 SUM(DECODE(D.K_NAME,'a',convert(d.value,number),NULL)) AS a1,

 SUM(DECODE(D.K_NAME,'a',convert(d.value,number),NULL)) AS b1, 

 SUM(DECODE(D.K_NAME,'a',D.STATUS,NULL)) AS a1_status,

 SUM(DECODE(D.K_NAME,'a',D.STATUS,NULL)) AS b1_status 

  FROM  

 P LEFT JOIN 

 D ON P.ID=D.id

 WHERE a  IN ('a','b')  

  GROUP BY P.NAME,P.ID  

 ORDER BY decode(a,null,0,a) DESC LIMIT 0,10


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章