亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

Oracle的數據表中行轉列與列轉行的操作實例講解

2024-08-29 13:58:44
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Oracle數據表中行轉列與列轉行的操作方法,這里分靜態和動態情況作出了分類討論,需要的朋友可以參考下
 

行轉列
一張表

Oracle的數據表中行轉列與列轉行的操作實例講解

查詢結果為

Oracle的數據表中行轉列與列轉行的操作實例講解

--行轉列

select years,(select amount from Tb_Amount as A where month=1 and A.years=Tb_Amount.years)as m1,(select amount from Tb_Amount as A where month=2 and A.years=Tb_Amount.years)as m2,(select amount from Tb_Amount as A where month=3 and A.years=Tb_Amount.years)as m3from Tb_Amount group by years

或者為

select years as 年份,sum(case when month='1' then amount end) as 一月, sum(case when month='2' then amount end) as 二月,sum(case when month='3' then amount end) as 三月from dbo.Tb_Amount group by years order by years desc

2.人員信息表包括姓名 時代  金額

Oracle的數據表中行轉列與列轉行的操作實例講解

顯示行轉列
姓名     時代       金額

姓名  年輕         中年       老年

張麗 1000000.00 4000000.00    500000000.00

孫子 2000000.00   12233335.00  4552220010.00

Oracle的數據表中行轉列與列轉行的操作實例講解

select uname as 姓名,SUM(case when era='年輕' then amount end) as 年輕,SUM(case when era='中年' then amount end) as 中年,SUM(case when era='老年' then amount end) as 老年from Tb_People group by uname order by uname desc

 3.學生表 [Tb_Student]

Oracle的數據表中行轉列與列轉行的操作實例講解

顯示效果

Oracle的數據表中行轉列與列轉行的操作實例講解

靜態SQL,指subject只有語文、數學、英語這三門課程。

select sname as 姓名,max(case Subject when '語文' then grade else 0 end) as 語文,max(case Subject when '數學' then grade else 0 end) as 數學,max(case Subject when '英語' then grade else 0 end) as 英語from dbo.Tb_Student group by sname order by sname desc

--動態SQL,指subject不止語文、數學、英語這三門課程。

declare @sql varchar(8000)set @sql = 'select sname as ' + '姓名'select @sql = @sql + ' , max(case Subject when ''' + Subject + ''' then grade else 0 end) [' + Subject + ']'from (select distinct Subject from Tb_Student) as aset @sql = @sql + ' from Tb_Student group by sname order by sname desc'exec(@sql)

oracle中Decode()函數使用 然后將這些累計求和(sum部分)

select t.sname AS 姓名,sum(decode(t.subject,'語文',grade,null))語文 ,sum(decode(t.subject,'數學',grade,null)) 數學,sum(decode(t.subject,'英語',grade,null)) 英語from Tb_Student t group by sname order by sname desc


列轉行

Oracle的數據表中行轉列與列轉行的操作實例講解

生成

Oracle的數據表中行轉列與列轉行的操作實例講解

sql代碼
生成靜態:

select *from (select sname,[Course ] ='數學',[Score]=[數學] from Tb_students union allselect sname,[Course]='英語',[Score]=[英語] from Tb_students union allselect sname,[Course]='語文',[Score]=[語文] from Tb_students)torder by sname,case [Course] when '語文' then 1 when '數學' then 2 when '英語' then 3 endgo --列轉行的靜態方案:UNPIVOT,sql2005及以后版本  SELECT sname,Subject, grade from dbo.Tb_students unpivot(grade for Subject in([語文],[數學],[英語]))as up GO   --列轉行的動態方案:UNPIVOT,sql2005及以后版本 --因為行是動態所以這里就從INFORMATION_SCHEMA.COLUMNS視圖中獲取列來構造行,同樣也使用了XML處理。 declare @s nvarchar(4000)select @s=isnull(@s+',','')+quotename(Name)from syscolumns where ID=object_id('Tb_students') and Name not in('sname')order by Colidexec('select sname,[Subject],[grade] from Tb_students unpivot ([grade] for [Subject] in('+@s+'))b')goselect  sname,[Subject],[grade]from  Tb_studentsunpivot  ([grade] for [Subject] in([數學],[英語],[語文]))b
 


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩中文在线| 97在线视频免费播放| 欧美在线观看网址综合| 久久电影一区二区| 亚洲国产婷婷香蕉久久久久久| 久热精品在线视频| 日韩亚洲第一页| 久久精品国产欧美亚洲人人爽| 久久精品国产一区| 亚洲一区二区三区视频| 美乳少妇欧美精品| 日韩有码在线视频| 久久久久久久久国产精品| 日韩最新免费不卡| 久久久爽爽爽美女图片| 国产精品老牛影院在线观看| 2023亚洲男人天堂| 91日本在线观看| 亚洲精品久久久久中文字幕欢迎你| 欧美激情videoshd| 亚洲精品福利免费在线观看| 97精品免费视频| 久热精品视频在线免费观看| 久久色精品视频| 91精品国产自产91精品| 日韩精品免费在线| 欧美性精品220| 国模吧一区二区| 亚洲天堂精品在线| 久久久91精品国产一区不卡| 国产精品电影网站| 日韩精品在线观| 亚洲精品之草原avav久久| 久久精品久久久久久| 欧美专区第一页| 欧美一级片免费在线| 欧美视频国产精品| 麻豆国产精品va在线观看不卡| 91在线直播亚洲| 国产玖玖精品视频| 啊v视频在线一区二区三区| 欧美日韩国产在线播放| 久久99精品久久久久久琪琪| 久久国产天堂福利天堂| 色哟哟亚洲精品一区二区| 国产视频亚洲视频| 亚洲国产一区二区三区在线观看| 久久亚洲综合国产精品99麻豆精品福利| 一区二区三区久久精品| 亚洲a∨日韩av高清在线观看| 国产精品r级在线| 亚洲伊人成综合成人网| 国产网站欧美日韩免费精品在线观看| 97视频免费观看| 中文字幕一区二区三区电影| 亚洲曰本av电影| 日本成人精品在线| 一本色道久久88综合日韩精品| 欧美性xxxx极品hd欧美风情| 亚洲欧美精品中文字幕在线| 中文字幕精品久久| 欧美专区国产专区| 人人爽久久涩噜噜噜网站| 亚洲福利在线视频| 欧美日韩国产精品一区| 亚洲精品一二区| 韩剧1988免费观看全集| 色偷偷av一区二区三区乱| 久久久久久久久久久亚洲| 成人写真视频福利网| 这里只有精品在线播放| 国产精品视频男人的天堂| 日韩一区二区欧美| 亚洲精品国产综合区久久久久久久| 大胆人体色综合| 国产精品黄视频| 国产精品av免费在线观看| 色噜噜国产精品视频一区二区| 国产欧美精品在线播放| 国内久久久精品| 欧美国产日韩一区二区在线观看| 国产欧美精品va在线观看| 91精品视频一区| 国产精品电影久久久久电影网| 亚洲一区二区三区成人在线视频精品| 欧美黄网免费在线观看| 91天堂在线视频| 欧美寡妇偷汉性猛交| 欧美成人自拍视频| 精品美女久久久久久免费| 亚洲电影av在线| 97激碰免费视频| 久久不射电影网| 久久这里只有精品视频首页| 久久全球大尺度高清视频| 亚洲欧洲在线视频| 亚洲精品网址在线观看| 91精品国产综合久久香蕉最新版| 第一福利永久视频精品| 欧美电影在线观看| 国自在线精品视频| 亚洲性线免费观看视频成熟| 国产精品丝袜久久久久久不卡| 久久精品亚洲一区| 欧美重口另类videos人妖| 亚洲美女视频网站| 欧美国产在线视频| 不卡中文字幕av| 欧美又大粗又爽又黄大片视频| 亚洲第一精品自拍| 色悠悠国产精品| 91精品视频在线| 国产精品久久久久久超碰| 大伊人狠狠躁夜夜躁av一区| 欧美最猛性xxxxx免费| 久久精品国产综合| 日韩二区三区在线| 亚洲精品自拍偷拍| 色偷偷av一区二区三区乱| 国产精品扒开腿做| 一区二区三区无码高清视频| 欧美激情久久久| 国产一区二区视频在线观看| 国产成人综合精品在线| 国产精品video| 国产欧美亚洲精品| 中文字幕日韩电影| www.xxxx欧美| 成人国内精品久久久久一区| 欧美在线亚洲一区| 亚洲欧美日韩精品久久奇米色影视| 日韩电影在线观看免费| 在线视频日韩精品| 成人免费观看网址| 日韩国产在线看| 久久久久久亚洲精品不卡| 国产精品99导航| 亚洲欧美中文字幕在线一区| 亚洲欧美在线免费观看| 欧美激情精品在线| 日韩在线观看电影| 国产欧美日韩精品专区| 欧美在线亚洲一区| 久久成人精品视频| 久久精视频免费在线久久完整在线看| 国产亚洲欧美日韩美女| 色系列之999| 国产精品午夜国产小视频| 1769国产精品| 国产精品久久久久久久电影| 日韩免费av在线| 92国产精品久久久久首页| 正在播放欧美视频| 日韩精品极品在线观看播放免费视频| 欧美大胆在线视频| 欧美亚洲另类视频| 亚洲人成在线电影| 成人福利在线观看| 欧美综合在线观看| 国内精品一区二区三区四区| 亚洲精品国产综合区久久久久久久| 91成人免费观看网站| 欧美黄色成人网| 久久夜色精品国产欧美乱|