Oracle行列轉換小結

目錄結構如下:
行轉列
列轉行
[一]、行轉列
?
1.1、初始測試數據
?
表結構:TEST_TB_GRADE
?
Sql代碼?
create table TEST_TB_GRADE?
(?
? ID??????? NUMBER(10) not null,?
? USER_NAME VARCHAR2(20 CHAR),?
? COURSE??? VARCHAR2(20 CHAR),?
? SCORE???? FLOAT?
)?
?初始數據如下圖:

???????????????????????
?
1.2、 如果需要實現如下的查詢效果圖:

????????????????????
?
這就是最常見的行轉列,主要原理是利用decode函數、聚集函數(sum),結合group by分組實現的,具體的sql如下:
Sql代碼?
select t.user_name,?
? sum(decode(t.course, '語文', score,null)) as CHINESE,?
? sum(decode(t.course, '數學', score,null)) as MATH,?
? sum(decode(t.course, '英語', score,null)) as ENGLISH?
from test_tb_grade t?
group by t.user_name?
order by t.user_name?
?
?
1.3、延伸
?
如果要實現對各門功課的不同分數段進行統計,效果圖如下:

????????????????
?
具體的實現sql如下:
Sql代碼?
select t2.SCORE_GP,?
? sum(decode(t2.course, '語文', COUNTNUM,null)) as CHINESE,?
? sum(decode(t2.course, '數學', COUNTNUM,null)) as MATH,?
? sum(decode(t2.course, '英語', COUNTNUM,null)) as ENGLISH?
from (?
? select t.course,?
???????? case when t.score? <60 then '00-60'?
????????????? when t.score >=60 and t.score <80? then '60-80'?
????????????? when t.score >=80 then '80-100' end as SCORE_GP,?
???????? count(t.score) as COUNTNUM?
? FROM test_tb_grade t?
? group by t.course,??
??????? case when t.score? <60? then '00-60'?
????????????? when t.score >=60 and t.score <80? then '60-80'?
????????????? when t.score >=80 then '80-100' end?
? order by t.course ) t2?
group by t2.SCORE_GP?
order by t2.SCORE_GP?
?
[二]、列轉行
?
1.1、初始測試數據
??????? 表結構:TEST_TB_GRADE2
Sql代碼?
create table TEST_TB_GRADE2?
(?
? ID???????? NUMBER(10) not null,?
? USER_NAME? VARCHAR2(20 CHAR),?
? CN_SCORE?? FLOAT,?
? MATH_SCORE FLOAT,?
? EN_SCORE?? FLOAT?
)?
?
??????? 初始數據如下圖:

???????
?
1.2、 如果需要實現如下的查詢效果圖:

??????????????????????
?
這就是最常見的列轉行,主要原理是利用SQL里面的union,具體的sql語句如下:
Sql代碼?
select user_name, '語文' COURSE , CN_SCORE as SCORE from test_tb_grade2??
union select user_name, '數學' COURSE, MATH_SCORE as SCORE from test_tb_grade2??
union select user_name, '英語' COURSE, EN_SCORE as SCORE from test_tb_grade2??
order by user_name,COURSE??
?
?也可以利用【 insert all into ... select 】來實現,首先需要先建一個表TEST_TB_GRADE3:
Sql代碼?
create table TEST_TB_GRADE3???
??? (??
????? USER_NAME VARCHAR2(20 CHAR),???
????? COURSE??? VARCHAR2(20 CHAR),???
????? SCORE???? FLOAT???
??? )???
?再執行下面的sql:
?
Sql代碼?
insert all?
into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, '語文', CN_SCORE)?
into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, '數學', MATH_SCORE)?
into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, '英語', EN_SCORE)?
select user_name, CN_SCORE, MATH_SCORE, EN_SCORE from test_tb_grade2;?
commit;?
?別忘記commit操作,然后再查詢TEST_TB_GRADE3,發現表中的數據就是列轉成行了。

?

轉載于:https://www.cnblogs.com/xiaofengfeng/p/3407095.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/273951.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/273951.shtml
英文地址,請注明出處:http://en.pswp.cn/news/273951.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

python- 進階 與flask的搭配使用---定時任務框架APScheduler學習詳解

APScheduler簡介 在平常的工作中幾乎有一半的功能模塊都需要定時任務來推動&#xff0c;例如項目中有一個定時統計程序&#xff0c;定時爬出網站的URL程序&#xff0c;定時檢測釣魚網站的程序等等&#xff0c;都涉及到了關于定時任務的問題&#xff0c;第一時間想到的是利用ti…

Mingw下g++編譯執行順序錯誤

今天寫一個簡單的線性表時&#xff0c;用Mingw中的g編譯、調試、運行時發現一個奇怪的現象&#xff1a;程序的執行順序與實際編寫順序不一致。 編譯環境&#xff1a;代碼編寫 win7下 editplus Mingw 4.3.3 g 代碼片段如下&#xff1a; 1 //function: create a list 2 //ti…

python系統學習1-程序設計的基本方法

一、程序設計基本方法 計算機與程序設計 編譯和解釋 程序的基本編寫方法 計算機編程 1、計算機與程序設計 &#xff08;1&#xff09;、計算機是根據指令操作數據的設備 功能性&#xff1a;對數據的操作、表現為數據計算、輸出輸入處理和結果存儲。 可編程性&#xff1a;…

python 系統學習實例1.1 - 華氏度與攝氏度的轉換

# C ( F - 32 ) / 1.8???????????????????????????????????????????????????????????????????????????????? # F C * 1.8 32?????????????????????????????…

EMS問題

如果EMS啟動后在運行時報出 JMS error: "Not allowed to create destination這個錯誤&#xff0c;可能就是你啟動方式的問題了進入到EMS的安裝目錄的bin目錄下&#xff0c;運行tibemsca.bat那個文件就好使了。轉載于:https://www.cnblogs.com/xiaotianyu/p/3421737.html

python 系統學習實例1.2 - 人民幣與美元的轉換

# RMB USD / 6.78???????????????????????????????????????????????????????????????????????????????? # USD RMB* 6.78 def tempConvert(): t input("請輸入數值:") …

HDTV(1920x1080)碼率和視頻質量關系的研究 2 (實驗結果)

上一篇文章中介紹了實驗的準備工作&#xff0c; HDTV&#xff08;1920x1080&#xff09;碼率和視頻質量關系的研究 1 &#xff08;前期準備&#xff09; 本文介紹一下實驗的結果。 首先來看一下主觀評價的試驗結果&#xff1a; 從實驗結果來看&#xff0c;可以得出以下結論&…

python爬蟲--如何爬取翻頁url不變的網站

參考 https://blog.csdn.net/c350577169/article/details/80410133

POJ 1745 Divisibility DP

POJ:http://poj.org/problem?id1745 A完這題去買福鼎肉片&#xff0c;和舍友去買滴~舍友感慨“這一天可以賣好幾百份&#xff0c;每份就算賺一塊錢。。那么一個月。。一年。。。” 我說“那我們以后去賣這個吧&#xff0c;餓了還能自己煮著吃” 哈哈&#xff0c;一群天真的少…

NGUI如何創建自己的精靈圖集

說實話其實很簡單,但是在不知道的情況下真的不好弄啊. 1. 選擇你要制作精靈圖集的圖片,可以選擇多張 2. 提倡使用快捷鍵Alt Shift M 會有如下窗口彈出,也可以NGUI --> Open-->Atlas Maker打開 我們看到在Sprites里面就是我們選擇的要制作圖集的圖片 當在Replace后面的輸…

C++ - 進階 1002

This time, you are supposed to find AB where A and B are two polynomials. Input Specification: Each input file contains one test case. Each case occupies 2 lines, and each line contains the information of a polynomial: K N?1?? a?N?1???? N?2??…

修改6S Fortran77 代碼,建立查找表

逐像元大氣校正&#xff0c;常預先計算查找表&#xff08;LUT&#xff0c;LookUp Tabel&#xff09;&#xff0c;6S大氣輻射傳輸模式也可以用來計算LUT。但6S源程序輸出信息多&#xff0c;且浮點數輸出精度低&#xff0c;不利于提取關鍵信息生成LUT&#xff0c;本文描述了怎樣修…

c++ 實例

#include "stdafx.h" #include <iostream> using namespace std; int main() { int a; a 4; cout<<a<<endl; return 0; }

VMware虛擬機與宿主無法復制的解決辦法

由于工作需要&#xff0c;上網機器使用虛擬機&#xff0c;因此需要經常來回的拷貝文件&#xff0c;而vmware從6.5一直走來到10.0.1&#xff0c;總是有一個問題很讓人苦惱---共享粘貼板總是會無故失效。經常實驗&#xff0c;發現可以經過以下方法臨時解決一下&#xff0c;雖然不…

c++ pat 乙級 --1001?害死人不償命的(3n+1)猜想

1001 害死人不償命的(3n1)猜想 &#xff08;15 分&#xff09; 卡拉茲(Callatz)猜想&#xff1a; 對任何一個正整數 n&#xff0c;如果它是偶數&#xff0c;那么把它砍掉一半&#xff1b;如果它是奇數&#xff0c;那么把 (3n1) 砍掉一半。這樣一直反復砍下去&#xff0c;最后…

【開源項目之路】jquery的build問題

在剛開始clone了jquery到本地build的時候&#xff0c;就遇到了問題。 “ENORESTARGET No tag found that was able to satisfy ...” 提示為bower install失敗&#xff0c;反復查找原因&#xff0c;最后在這兒看到同樣類似的問題&#xff0c;貌似是git協議的連接問題&#xff0…

適配ios7

if ([self respondsToSelector:selector(edgesForExtendedLayout)]){self.edgesForExtendedLayout UIRectEdgeNone;self.extendedLayoutIncludesOpaqueBars NO;self.modalPresentationCapturesStatusBarAppearance NO;} 轉載于:https://www.cnblogs.com/jiackyan/p/3441378.…

c++ pat 乙級 -------1002 讀入一個正整數 n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。

1002 寫出這個數 &#xff08;20 分&#xff09; 讀入一個正整數 n&#xff0c;計算其各位數字之和&#xff0c;用漢語拼音寫出和的每一位數字。 輸入格式&#xff1a; 每個測試輸入包含 1 個測試用例&#xff0c;即給出自然數 n 的值。這里保證 n 小于 10?100??。 輸出…

USACO SEC.1.3 No.1 Mixing Milk

題意&#xff1a;需要收購總數為N的牛奶&#xff0c;現在有M個牛奶供應商&#xff08;總量足夠&#xff09;&#xff0c;給出總數和單價&#xff0c;求最小的花銷。 核心&#xff1a;基本的貪心解法&#xff0c;按單價排序逐個選取。 目的在于熟悉基本的貪心法的基本方法和思路…

c++ 獲取數組的長度

//獲得數組的長度 template<typename T> int count(T& x) { int s1 sizeof(x); int s2 sizeof(x[0]); int result s1 / s2; return result; }