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

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

2024-08-31 01:02:10
字體:
供稿:網(wǎng)友
最近面試遇到了一道面試題,頓時有點迷糊,只說出了思路,后來百度了一下,整理了一下思路,于是記錄下來,方便以后學習。(面試題請參見附件)

相關(guān)的數(shù)據(jù)表:

1.Score表

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

 
2.[User]表

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

 
SQL語句如下:

--方法一:靜態(tài)SQL

復制代碼 代碼如下:


SELECT * FROM
(SELECT UID,Name, Score,ScoreName FROM Score,[User] WHERE Score.UID=[User].ID) AS SourceTable
PIVOT(AVG(Score)FOR ScoreName IN ([英語], [數(shù)學])) AS a


--方法二:動態(tài)SQL

復制代碼 代碼如下:


DECLARE @s NVARCHAR(4000)
SELECT @s = ISNULL(@s + ',', '') + QUOTENAME(ScoreName)
FROM (select distinct ScoreName from Score) as A ---列名不要重復

Declare @sql NVARCHAR(4000)
SET @sql='
select r.* from
(select UID,Name,ScoreName,Score from Score,[User] where Score.UID=[User].ID) as t
pivot
(
max(t.Score)
for t.ScoreName in ('+@s+')
) as r'
EXEC( @sql)


--方法三:Case When

復制代碼 代碼如下:


select
row_number() OVER(ORDER BY [User].ID) as 編號,
UID as 用戶編號,
Name as 姓名,
max(case ScoreName when '英語' then Score else 0 end) 英語,
max(case ScoreName when '數(shù)學' then Score else 0 end) 數(shù)學
from Score,[User] WHERE Score.UID=[User].ID
group by UID,[User].ID,Name

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 玉田县| 西乡县| 湖北省| 绥中县| 宁蒗| 扶沟县| 都江堰市| 广西| 孟村| 镇雄县| 曲松县| 富源县| 普宁市| 汝阳县| 嘉荫县| 清原| 孝昌县| 宝坻区| 渭源县| 合江县| 二连浩特市| 合肥市| 师宗县| 桑日县| 东乡| 延吉市| 乌兰县| 库伦旗| 西丰县| 安徽省| 永年县| 吐鲁番市| 曲周县| 巴楚县| 贵港市| 将乐县| 共和县| 东丽区| 横峰县| 崇州市| 治多县|