国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

table 行轉列的sql詳解

2024-08-31 00:59:39
字體:
來源:轉載
供稿:網友
一、要求
1 創建數據表
CREATE TABLE [dbo].[StuScore](
[stuid] [int] NOT NULL,
[subject] [nvarchar](30) NULL,
[score] [decimal](5, 1) NULL
)
2 插入測試數據
stuid subject score
3 chinese 76.0
3 math 73.0
4 chinese 82.0
5 chinese 66.0
5 math 93.0
6 chinese 67.0
7 math 83.0
8 chinese 77.0
8 math 84.0
3 行轉列后的結果
stuid chinese math
3 76.0 73.0
4 82.0 0.0
5 66.0 93.0
6 67.0 0.0
7 0.0 83.0
8 77.0 84.0
二 、分析
1 行轉列,一個重點就是怎么樣知道有多少列,怎么樣創建這些列?我們可以先把這個問題擱置,而假設這些列是已知的。 例如示例數據中,可以先假設subject的數據[chinese,math]是已知的,這樣問題就簡化了許多
2 當已知了chinese,math后,我們至少要先得到轉換后的tabel結構
如下;
select stuid, 0 as chinese, 0 as math from dbo.StuScore
結果如下
stuid chinese math
3 0 0
3 0 0
4 0 0
5 0 0
5 0 0
6 0 0
7 0 0
8 0 0
8 0 0
3 接著就需要往這個數據集中去填充chinese, math的數據
select stuid,
case subject when 'chinese' then score else 0 end as chinese,
case subject when 'math' then score else 0 end as math
from dbo.StuScore
結果如下:
stuid chinese math
3 76.0 0.0
3 0.0 73.0
4 82.0 0.0
5 66.0 0.0
5 0.0 93.0
6 67.0 0.0
7 0.0 83.0
8 77.0 0.0
8 0.0 84.0
4 細心的讀者會發現步驟3中的結果與我們想要的已經非常接近了,只需再做一個sum()處理,就OK了
select stuid,
sum(case subject when 'chinese' then score else 0 end ) as chinese,
sum(case subject when 'math' then score else 0 end ) as math
from dbo.StuScore group by stuid
得到的正是我們想要的結果
stuid chinese math
3 76.0 73.0
4 82.0 0.0
5 66.0 93.0
6 67.0 0.0
7 0.0 83.0
8 77.0 84.0
是不是現在就已經完成了呢?答案是否定的。前面我們已經說過,是為了簡化問題,在假設已經知道了subject數據的情況下,這么處理的,實際上subject的數據是可變的,未知的,接下來就是要解決這個問題了
5 要獲取subject的數據其實很簡單
select distinct subject from dbo.StuScore
獲取以后怎樣得到case subject when 'chinese' then score else 0 end 這種語句?
可以根據subject的值去動態的組sql語句
看下面的一段代碼
declare @sql varchar(2000)
set @sql=''
select @sql =@sql+ ',case subject when '''+subject+''' then 1 else 0 end as ' + subject
from (select distinct subject from dbo.StuScore) as sub
print @sql
message打印的信息如下:
,case subject when 'chinese' then 1 else 0 end as chinese,case subject when 'math' then 1 else 0 end as math
6 最后我們就需要將前面步驟綜合起來,得到最終的sql
declare @sql varchar(2000)
set @sql='select stuid'
select @sql =@sql+ ',sum(case subject when '''+subject+''' then score else 0 end) as ' + subject
from (select distinct subject from dbo.StuScore) as sub
set @sql=@sql + ' from dbo.StuScore group by stuid'
exec(@sql)
stuid chinese math
3 76.0 73.0
4 82.0 0.0
5 66.0 93.0
6 67.0 0.0
7 0.0 83.0
8 77.0 84.0
至此,整個分析過程和結果就都出來了。
初試寫文章, 多包涵,指正。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金坛市| 海阳市| 阜南县| 炎陵县| 苏尼特左旗| 肇东市| 哈巴河县| 榕江县| 伊宁市| 武威市| 洞头县| 仁寿县| 博客| 黄浦区| 霍山县| 苏尼特右旗| 石棉县| 甘肃省| 碌曲县| 卢龙县| 铜鼓县| 余姚市| 新巴尔虎左旗| 利川市| 达拉特旗| 贡山| 叶城县| 江门市| 子洲县| 长沙市| 建水县| 象州县| 边坝县| 松滋市| 双桥区| 宜兰县| 天台县| 长兴县| 从江县| 威信县| 乾安县|