色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

Oracle中實現行列互轉的方法分享

瀏覽:2日期:2023-09-15 20:49:58
目錄一、使用Case when 實現列轉為行(多行一列-->一行多列)1.1、實現效果1.2、列轉行(多行一列-->一行多列)二、使用 Case When 實現行轉列(一行多列-->多行一列)2.1、實現效果2.2、行轉列(一行多列-->多行一列)三、將結果集轉為一行四、將結果集轉為多行一、使用Case when 實現列轉為行(多行一列-->一行多列)1.1、實現效果

①原表效果

②實現將Course課程列內容轉為行效果【實現將每個人員的課程信息合成一行,且獲取到課程總分】

1.2、列轉行(多行一列-->一行多列)

sql語句

SELECT NAME,MAX(CASE WHEN COURSE='語文' THEN SCORE END) '語文',MAX(CASE WHEN COURSE='數學' THEN SCORE END) '數學',MAX(CASE WHEN COURSE='英語' THEN SCORE END) '英語',MAX(CASE WHEN COURSE='物理' THEN SCORE END) '物理',SUM(SCORE) '總分' FROM stu GROUP BY NAME;二、使用 Case When 實現行轉列(一行多列-->多行一列)2.1、實現效果

①原表效果

②實現將多個數字列轉為一列效果

2.2、行轉列(一行多列-->多行一列)

sql語句

SELECT NAME, CASE WHEN LV = 1 THEN '語文' --常量 WHEN LV = 2 THEN '數學' --常量 WHEN LV = 3 THEN '英語' --常量 WHEN LV = 4 THEN '物理' --常量 END 科目, CASE WHEN LV = 1 THEN langu --列名 WHEN LV = 2 THEN math--列名 WHEN LV = 3 THEN english--列名 WHEN LV = 4 THEN pycial--列名 END 成績 FROM ( SELECT * FROM course, (SELECT LEVEL LV FROM DUAL CONNECT BY LEVEL <= 4) ) --成績對應的列數ORDER BY 1, 2;三、將結果集轉為一行

①查詢到每個部門的人數

--查詢每個部門的人數 SELECT DEPTNO, COUNT(1) CN FROM EMP GROUP BY DEPTNO ORDER BY 1;

②將查詢到的每個部門人數的結果集【轉為一行】

--將上面的結果轉為一行,可以使用 SUM 或者 COUNT 來求出。 SELECT SUM(CASE WHEN DEPTNO = 10 THEN 1 END) D_10,SUM(CASE WHEN DEPTNO = 20 THEN 1 END) D_20,SUM(CASE WHEN DEPTNO = 30 THEN 1 END) D_30 FROM EMP; --也可以使用下面的方法。 SELECT CASE WHEN DEPTNO = 10 THEN CN END D_10,CASE WHEN DEPTNO = 20 THEN CN END D_20,CASE WHEN DEPTNO = 30 THEN CN END D_30 FROM (SELECT DEPTNO, COUNT(1) CN FROM EMP GROUP BY DEPTNO); --和剛講的一樣,生成了三行三列數據,使用 MAX 來獲取。 SELECT MAX(CASE WHEN DEPTNO = 10 THEN CN END) D_10,MAX(CASE WHEN DEPTNO = 20 THEN CN END) D_20,MAX(CASE WHEN DEPTNO = 30 THEN CN END) D_30 FROM (SELECT DEPTNO, COUNT(1) CN FROM EMP GROUP BY DEPTNO);四、將結果集轉為多行

SELECT MAX(CASE JOB WHEN 'CLERK' THEN ENAME END) CLERK,MAX(CASE JOB WHEN 'ANALYST' THEN ENAME END) ANALYST, MAX(CASE JOB WHEN 'MANAGER' THEN ENAME END) MANAGER,MAX(CASE JOB WHEN 'PRESIDENT' THEN ENAME END) PRESIDENT,MAX(CASE JOB WHEN 'SALESMAN' THEN ENAME END) SALESMAN FROM (SELECT ENAME,JOB,--每組都是從 1 開始排序,而每列里面只有一組有數據。也就是 RN 相同的在每列里面只有一條數據 ROW_NUMBER() OVER(PARTITION BY JOB ORDER BY ENAME) RN FROM EMP) GROUP BY RN ORDER BY RN;

到此這篇關于Oracle中實現行列互轉的方法分享的文章就介紹到這了,更多相關Oracle行列互轉內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Oracle 數據庫
相關文章:
主站蜘蛛池模板: 亚洲精品国产成人7777 | 国产日韩精品视频一区二区三区 | 国产免费一区二区三区在线 | 免费在线观看毛片 | 99精品久久久久久久免费看蜜月 | 成人国产精品免费视频不卡 | 欧美一区二区三区国产精品 | 欧美日韩一区二区在线观看视频 | 国产成人在线播放 | 久久影院视频 | 国产成人久久精品一区二区三区 | 手机看片亚洲 | 美日韩一区二区三区 | 中国农村一级毛片 | 欧美极品欧美精品欧美视频 | 国产v综合v亚洲欧美大另类 | 一级一级毛片免费播放 | 在线视频中文 | 亚洲一区在线免费观看 | 色偷偷亚洲男人天堂 | 亚洲天堂国产精品 | 日韩精品午夜视频一区二区三区 | 国产一级做a爰片久久毛片男 | 久草视频在线首页 | 清纯偷拍精品视频在线观看 | 亚洲精品456在线播放无广告 | 三级黄色片网址 | 欧美另类精品一区二区三区 | 100000免费啪啪18免进 | 深夜福利视频在线观看免费播放 | 亚洲人成亚洲精品 | 亚洲久久久久 | 国产爽的冒白浆的视频高清 | avtt天堂网 手机资源 | 亚洲视频中文字幕在线观看 | 久色视频在线观看 | 99久久精品国产自免费 | 一级片免费的 | 久久精品视频在线播放 | 国产乱理片在线观看夜 | 一区二区三区视频在线观看 |