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

首頁 > 數據庫 > SQL Server > 正文

mssql關于一個表格結構的另外一種顯示(表達意思不變)

2024-08-31 00:56:46
字體:
來源:轉載
供稿:網友
一、需求

  由于表達能力不好,直接上圖。在mssql環境中需要把圖1的表轉化成圖2的表:

mssql關于一個表格結構的另外一種顯示(表達意思不變)

圖1圖2

二、分析

  

mssql關于一個表格結構的另外一種顯示(表達意思不變)

  圖3

2.1創建表

復制代碼 代碼如下:


create table #tb
(ID int primary key,
Class nvarchar(max),
[Subject] nvarchar(max),
Score int)
insert into #tb values(1,'一(1)班','語文','92')
insert into #tb values(2,'一(1)班','數學','91')
insert into #tb values(3,'一(1)班','英語','93')
insert into #tb values(4,'一(2)班','數學','94')
insert into #tb values(5,'一(2)班','語文','95')
insert into #tb values(6,'一(2)班','英語','96')
insert into #tb values(7,'一(3)班','數學','94')
insert into #tb values(8,'一(3)班','語文','96')
insert into #tb values(9,'一(3)班','英語','97')
select * from #tb


2.2把圖3中的第一張表轉化為第二張表

復制代碼 代碼如下:


select [Subject], [一(1)班]=[Score]
,[一(2)班]=[Score]
,[一(3)班]=[Score]
from #tb


2.3把圖3中的第二張表轉化為第三張表

復制代碼 代碼如下:


--觀察第二張表,表顯然很多成績是錯誤的,所以要消除錯誤

--消除錯誤的方法:先把錯誤的成績設置為0,然后每一行取最大的數作為成績,并按照科目來分組顯示
select subject,[一(1)班]=case when [Class]='一(1)班' then [Score] else 0 end
,[一(2)班]= case when [Class]='一(2)班' then [Score] else 0 end
,[一(3)班]=case when [Class]='一(3)班' then [Score] else 0 end
from #tb


2.4 把圖3中的第三張表轉化為第四張表

復制代碼 代碼如下:


select subject, [一(1)班]=max( case when [Class]='一(1)班' then [Score] else 0 end)
,[一(2)班]=max( case when [Class]='一(2)班' then [Score] else 0 end)
,[一(3)班]=max( case when [Class]='一(3)班' then [Score] else 0 end)
from #tb group by subject


2.5簡化上面的寫法

復制代碼 代碼如下:


declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename(Class)+'=max( case when [Class]='+quotename(Class,'''')+' then [Score] else 0 end)'
from #tb group by Class
--print @s
exec('select [Subject]'+@s+' from #tb group by [Subject]')


三、簡化分析和需求延伸

3.1簡化分析

  上面的簡化,對于菜鳥級的我,理解著還是非常吃力的,所以我是在知道答案后,用 print @s一步一步的去分析的,特別是在select @s=@s+.....的時間,在這里我找到了一種把單列數據連接成字符串的方法。

mssql關于一個表格結構的另外一種顯示(表達意思不變)

圖4

3.2需求延伸

  或許上面的需求太簡單,那么我們現在引出復雜點的需求,動態獲取班級的成績,比如我們的需求可能是列出部分班級的成績,代碼如下:

復制代碼 代碼如下:


declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename(Class)+'=max( case when [Class]='+quotename(Class,'''')+' then [Score] else 0 end)'
from #tb
where Class in(你想要的班級)
group by Class
--print @s
exec('select [Subject]'+@s+' from #tb group by [Subject]')


四、總結

  本文主要實現表的另外一種顯示,通常用于動態顯示數據的例子中。難點在于分析過程和一些基本的sql語法。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产伦精品免费视频| 国产欧美精品在线播放| 欧美性感美女h网站在线观看免费| 国产mv免费观看入口亚洲| 97视频在线观看免费高清完整版在线观看| 国产日韩欧美在线看| 日韩av综合网站| 亚洲系列中文字幕| 欧美日韩亚洲一区二区三区| 欧美又大又粗又长| 日韩成人在线视频观看| 日韩精品免费在线观看| 欧美成人免费大片| 亚洲欧美在线x视频| 欧美视频裸体精品| 国产日韩欧美成人| 一区二区中文字幕| 欧美大片在线看免费观看| 日韩精品视频三区| 久久久久久久久网站| 中文字幕日韩av综合精品| 91极品女神在线| 亚洲v日韩v综合v精品v| 91中文字幕在线| 中文在线资源观看视频网站免费不卡| 夜夜嗨av一区二区三区四区| 日韩av在线一区二区| 日韩小视频在线观看| 亚洲激情中文字幕| 在线观看精品自拍私拍| 在线播放国产一区二区三区| 色偷偷888欧美精品久久久| 日韩在线中文字| 日韩美女免费观看| 久久成人亚洲精品| 国产精品美女主播在线观看纯欲| 深夜成人在线观看| 久久久久久999| 日韩欧美在线第一页| 日韩电影免费在线观看| 高清日韩电视剧大全免费播放在线观看| 国外成人免费在线播放| 91久久国产综合久久91精品网站| 国产精品亚洲一区二区三区| 在线看日韩欧美| 国产成人久久久| 色综合久综合久久综合久鬼88| 法国裸体一区二区| 欧美精品videos另类日本| 不卡av日日日| 国产91热爆ts人妖在线| 国内精品久久久久久久久| 欧美成人精品不卡视频在线观看| 九九热最新视频//这里只有精品| 国产日韩欧美夫妻视频在线观看| 欧美一级视频免费在线观看| 亚洲福利在线看| 久久精品视频播放| 国产精品久久久久秋霞鲁丝| 中文字幕一精品亚洲无线一区| 欧美日韩美女视频| 1769国内精品视频在线播放| 国产欧美一区二区三区视频| 性夜试看影院91社区| 欧美性生交xxxxx久久久| 岛国精品视频在线播放| 色妞色视频一区二区三区四区| 久久男人资源视频| 欧美视频一区二区三区…| 亚洲精品狠狠操| 91精品啪aⅴ在线观看国产| 91日韩在线视频| 国产精品久久久久久婷婷天堂| 精品欧美aⅴ在线网站| 尤物yw午夜国产精品视频| 超碰91人人草人人干| 久久在线免费观看视频| 亚洲欧美激情另类校园| 国产精品久久久久久婷婷天堂| 国产精品久久婷婷六月丁香| 精品久久香蕉国产线看观看gif| 91精品国产综合久久男男| 欧美激情免费观看| 久久久精品视频在线观看| 亚洲人成在线播放| 黄色成人av网| 中文字幕亚洲一区二区三区| 欧美巨猛xxxx猛交黑人97人| 久久久久亚洲精品国产| 日韩中文在线中文网三级| 亚洲缚视频在线观看| 国产视频福利一区| 在线视频亚洲欧美| 在线观看久久av| 亚洲欧美综合另类中字| 成人黄色免费在线观看| 日韩欧美在线中文字幕| 亚洲成人av中文字幕| 亚洲欧美国产日韩天堂区| 国产精品一区久久| 欧美激情三级免费| 美女视频黄免费的亚洲男人天堂| 自拍偷拍亚洲精品| 国产成人久久久| 日韩av第一页| 国产精品www网站| 亚洲视频axxx| 日韩精品免费一线在线观看| 国产91成人在在线播放| 久久综合九色九九| 成人写真福利网| 亚洲91精品在线观看| 亚洲最大激情中文字幕| 亚洲人成电影在线播放| 日韩免费精品视频| 少妇精69xxtheporn| 亚洲a在线观看| 久久久电影免费观看完整版| 欧美在线一级va免费观看| 亚洲精品一区二区网址| 久久久久久久久久国产精品| 亚洲欧美视频在线| 亚洲第一区中文99精品| 欧美在线观看日本一区| 国产精品男人的天堂| 亚洲综合社区网| 91久久综合亚洲鲁鲁五月天| 亚洲精品在线视频| 亚洲欧洲一区二区三区久久| xx视频.9999.com| 国产精品久久久久久久久久三级| 久久亚洲国产成人| 亚洲已满18点击进入在线看片| 亚洲人永久免费| 亚洲色图国产精品| 日韩在线免费高清视频| 57pao成人国产永久免费| 亚洲福利在线视频| 亚洲影院高清在线| 国产人妖伪娘一区91| 亚洲精品乱码久久久久久金桔影视| 亚洲第一精品久久忘忧草社区| 伊人伊人伊人久久| 日本道色综合久久影院| 亚洲精品小视频在线观看| 中文字幕日韩欧美| 91精品国产91久久久久久久久| 亚洲美女精品成人在线视频| 九九精品视频在线| 亚洲天堂久久av| 久久艳片www.17c.com| 国产一区二区三区欧美| 日韩高清中文字幕| 亚洲国产91精品在线观看| 少妇高潮久久久久久潘金莲| 国产99久久精品一区二区永久免费| 一区二区福利视频| 国产精品美女无圣光视频| 亚洲视频综合网| 日韩精品在线观看网站| 2019中文在线观看| 国产xxx69麻豆国语对白| 91沈先生作品| 美日韩精品视频免费看|